zoukankan      html  css  js  c++  java
  • 解决存储过程中拼接的SQL字符串超长导致sql语句被截取的问题

    今天遇到了一个奇葩的问题:存储过程中的sql字符串拼接的太长,超出了分页存储过程执行sql参数的nvarchar(4000)的长度。

    没办法,只能修改自己的存储过程,因为分页存储过程是不能动的。

    开始想到的方法是将里层的select语句抽出来,用exec(strInnerSql)执行,将查询胡来的数据放到临时表中,在@s中用临时表获取数据,结果以时报告终

    错误原因:执行@s语句的时候找不到执行exec(strInnerSql)产生的临时表

    好郁闷啊,怎么会这样呢,明明在一个存储过程中执行的,怎么临时表就获取不到呢??????????

    折腾了半天,这样还是搞不定

    无奈,只能将exec(strInnerSql)执行的那个sql抽出来,在代码中执行,让他产生临时表,然后再在存储过程中调用

    惊奇,居然成功了!!!!!!!!

    神啊,能告诉我为什么吗????????????????

    第一种方法为什么不行,第二种方法就行了啊

    哪位大神路过,一定要告诉我问什么!!!!!!!!!!!!!!

  • 相关阅读:
    洛谷P1218 [USACO1.5]特殊的质数肋骨 Superprime Rib
    洛谷 P1062 数列
    洛谷 P2822 组合数问题
    HDU 6112 今夕何夕
    poj 2115 C Looooops
    HDU 6092 Rikka with Subset
    poj 2720 Last Digits
    poj 1254 Hansel and Grethel
    poj 1222 EXTENDED LIGHTS OUT
    poj 2459 Sumsets
  • 原文地址:https://www.cnblogs.com/stevenjson/p/4026598.html
Copyright © 2011-2022 走看看