加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

SQLSERVER 中使用in  传入数组参数解决方案

(2012-12-18 13:23:48)
标签:

sqlserver

in

数组参数

杂谈

分类: 数据库知识

     最近开发过程中,经常要向sql中传入一段带逗号的字符串为参数,例如:select a.* from a where a.id in(1,2,3,4,5,6);如果我们传入的参数是一个字符串,那么sqlserver则会报错,因为sqlserver中会自动将这个字符串两头加上一个单引号"'",例如'1,2,3,4,5,6',所以我们想要查询的结果集当然为空;今天,突然想到一个解决的方案,就是拼接sql,虽然是很老套的方法,但是能解决这个问题我还是很开心的;

     方法如下:

       public void test(int[] aaa)

    {

       String sql="SELECT MT.* from MANU_TASKINFO MT  where MT.TASK_ID in (";

       for(int m=0;m
      {
         sql=sql+aaa[m]+",";
      }
      sql=sql+aaa[aaa.length-1]+")";//这是整形数组最后一个值,要加反括号,构成完成的sql语句,所以,得单独列出来;

      .........

      .........

      .........

}

如此拼接好的sql就不会报错或查询结果集为空了

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有