sql – 如何检查存储在varchar列中的逗号分隔列表中是否包含数字?
发布时间:2020-05-24 15:09:09 所属栏目:MsSql 来源:互联网
导读:我有一个varchar列categoryIds的表.它包含一些用逗号分隔的ID,例如: id categoryIds-------------------- 1 3,7,12,33,43 我想做一个select语句并检查该列中是否存在int.像这样的东西: select * from myTable where 3 in (categoryIds) 我知道这可以通
|
我有一个varchar列categoryIds的表.它包含一些用逗号分隔的ID,例如: id categoryIds -------------------- 1 3,7,12,33,43 我想做一个select语句并检查该列中是否存在int.像这样的东西: select * from myTable where 3 in (categoryIds) 我知道这可以通过this在MySQL中实现,但是它也可以在SQL Server中完成吗? 我已经尝试将int转换为char,它运行以下语句: select * from myTable where '3' in (categoryIds) 但它似乎没有任何“开箱即用”支持逗号分隔列表,因为它什么都不返回. 解决方法您应该重新设计此表以将这些值从逗号分隔为单独行.但是,如果无法做到这一点,那么您将继续进行字符串比较:DECLARE @id INT = 3 DECLARE @stringId VARCHAR(50) = CAST(@id AS VARCHAR(50)) SELECT * FROM MyTable WHERE categoryIds = @stringId -- When there is only 1 id in the table OR categoryIds LIKE @stringId + ',%' -- When the id is the first one OR categoryIds LIKE '%,' + @stringId + ',%' -- When the id is in the middle OR categoryIds LIKE '%,' + @stringId -- When the id is at the end (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql – 在Access中更新表
- SQL Server 递归SQL查询语句功能实例
- sql-server – 主键列上的非聚簇索引?
- SQLServer 2008 Merge语句的OUTPUT功能
- sql-server-2008 – 与SQL Server分开安装Team Foundation
- sql – 如何内连接多个列?
- sql-server – 如何列出或搜索数据库中的所有列名?
- MySQL索引的缺点以及MySQL索引在实际操作中有哪些事项
- azure-sql-database – Azure Blob存储的事务访问
- sql – NHibernate linq – 在映射时使用lambda表达式代替f
