DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: jeff1314
今日帖子: 22
在线用户: 9
导航: 论坛 -> 数据库专区 斑竹:liumazi,waterstone  
作者:
男 iamcws (你健康我快乐) ★☆☆☆☆ -
普通会员
2017/3/25 13:39:49
标题:
SQL Server,如何查询一个int型数据是否存在一个表的varchar型字段中?请老师指教!谢谢! 浏览:1213
加入我的收藏
楼主: SQL Server,如何查询一个int型数据是否存在一个表的varchar型字段中?请老师指教!谢谢!
----------------------------------------------
不要等到孤独寂寞时才想起朋友,不要等到穷困潦倒时才想起发奋,不要等到疾病缠身时才想起健康。。。
作者:
男 iamcws (你健康我快乐) ★☆☆☆☆ -
普通会员
2017/3/25 13:45:04
1楼: 表中varchar型字段的内容格式为以逗号隔开int型数据,如varchar型字段的内容为“1,2,3,4,5”。例如,查询 3 是否存在varchar型字段中,SQL语句怎样写?谢谢!
----------------------------------------------
不要等到孤独寂寞时才想起朋友,不要等到穷困潦倒时才想起发奋,不要等到疾病缠身时才想起健康。。。
作者:
男 iamcws (你健康我快乐) ★☆☆☆☆ -
普通会员
2017/3/25 13:48:34
2楼: 我的存储过程如下:
create proc up_chk_item_cmdid
  @p_CmdID int -- 指令ID
as
  set NoCount on
  set ArithAbort off
  set ArithIgnore on
  set Ansi_Warnings off
  
  if exists(select ItemID from Item698 where @p_CmdID in CmdIDList)
    return 1
  else
    return 0
提交此存储过程后报错了,错误消息如下:
消息 170,级别 15,状态 1,过程 up_chk_item_cmdid,第 10 行
第 10 行: 'CmdIDList' 附近有语法错误。
----------------------------------------------
不要等到孤独寂寞时才想起朋友,不要等到穷困潦倒时才想起发奋,不要等到疾病缠身时才想起健康。。。
作者:
男 iamcws (你健康我快乐) ★☆☆☆☆ -
普通会员
2017/3/25 13:51:22
3楼: Item698表中的CmdIDList字段为varchar型
----------------------------------------------
不要等到孤独寂寞时才想起朋友,不要等到穷困潦倒时才想起发奋,不要等到疾病缠身时才想起健康。。。
作者:
男 iamcws (你健康我快乐) ★☆☆☆☆ -
普通会员
2017/3/25 15:52:36
4楼: 已解决!存储过程如下:

--==========
-- up_chk_plan_itemid
-- 功能: 检查方案信息中是否已关联项目ID
--==========
if exists (select * from sysobjects where name = 'up_chk_plan_itemid')
  drop proc up_chk_plan_itemid
go

create proc up_chk_plan_itemid
  @p_ItemID varchar(10) -- 指令ID
as
  set NoCount on
  set ArithAbort off
  set ArithIgnore on
  set Ansi_Warnings off
  
  if exists(select PlanID from Plan698 where ItemIDList = @p_ItemID or ItemIDList like @p_ItemID + ',%' or ItemIDList like '%,' + @p_ItemID + ',%' or ItemIDList like '%,' + @p_ItemID)
    return 1
  else
    return 0
----------------------------------------------
不要等到孤独寂寞时才想起朋友,不要等到穷困潦倒时才想起发奋,不要等到疾病缠身时才想起健康。。。
作者:
男 xieyunc (xieyunc) ★☆☆☆☆ -
普通会员
2017/4/13 23:42:01
5楼: @iamcws 这个会不会有问题啊?
例如
输入参数为 3 
表中ItemIDList内容为:1,9,13,17  
查询结果仍然为 return 1 这个明显是错误的
如果改为:
 if exists(select PlanID from Plan698 where ','+ItemIDList+',' like '%,' + @p_ItemID + ',%')
    return 1
  else
    return 0

应该就可以了,而且不需要那么多的判断条件。
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行46.875毫秒 RSS