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

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

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

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

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

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

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

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

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

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

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

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

  • 相关阅读:
    JS(react)里面Json、String、Map、Object之间的转换
    react里面的几个内容
    object.assign的理解
    buffers与cached的区别
    vncserver错误
    Ubuntu可视化jupyter notebook
    ubuntu可视化桌面安装问题
    素数序列的生成及其应用 Version 2.2
    demo14-修改标签里面的属性
    demo13-修改元素的内容
  • 原文地址:https://www.cnblogs.com/stevenjson/p/4026598.html
Copyright © 2011-2022 走看看