「已注销」 2018-01-17 08:49 采纳率: 0%
浏览 3330
已结题

mysql将一个以逗号分隔的数字字符串转出数字

select * from user where id in (Ids);

说明,Ids是存储过程传过来的一个拼接的数字字符串,(1,2,3,4,5),现在的问题是。这样in之后
它只会找id=1的记录。后面的记录找不出来。不知为何。还请各位大神指点
,为什么会这麼拼接。是为我的id是一个临时表里。不能用来关联。因为存储过程里有狠多
地方用到Ids,临时表只能select一次。所以用了这个方法。
这是拼接语句varCampId是动态查询的。根据条件。可能一个。可能多个。
SET @tmpCampIds = CONCAT(@tmpCampIds, varCampId, ',');

  • 写回答

7条回答 默认 最新

  • qq_33674212 2018-01-17 08:50
    关注

    可以专门写一个函数,传入一个参数,函数里面直接拼接参数里面的值

    评论

报告相同问题?

悬赏问题

  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退
  • ¥20 win系统的PYQT程序生成的数据如何放入云服务器阿里云window版?
  • ¥50 invest生境质量模块