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

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

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

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

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

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

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

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

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

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

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

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

  • 相关阅读:
    ububtu 14.04 问题集合
    ubuntu grub 引导修复
    Ubuntu 下 glpk 的安装及使用
    ubuntu vim 7.4 编译安装
    ubuntu 12.04 clang 3.4 安装
    CMakeLists实战解读--YouCompleteMe
    Flume安装及部署
    SpringBoot整合kafka
    linux安装kafka
    Linux安装zookeeper
  • 原文地址:https://www.cnblogs.com/stevenjson/p/4026598.html
Copyright © 2011-2022 走看看