asp.net – SQL使用逗号分隔值和IN子句
发布时间:2020-12-16 00:00:26 所属栏目:asp.Net 来源:网络整理
导读:我正在开发一个ASP.NET应用程序,并将一个字符串值“1,2,3,4”传递给一个过程,以选择那些IN(1,4)的值,但它说“转换失败时转换varchar值’1,4’到数据类型int.“ 这是aspx代码: private void fillRoles(){ /*Read in User Profile Data from database */ Data
我正在开发一个ASP.NET应用程序,并将一个字符串值“1,2,3,4”传递给一个过程,以选择那些IN(1,4)的值,但它说“转换失败时转换varchar值’1,4’到数据类型int.“
这是aspx代码: private void fillRoles() { /*Read in User Profile Data from database */ Database db = DatabaseFactory.CreateDatabase(); DbCommand cmd = db.GetStoredProcCommand("sp_getUserRoles"); db.AddInParameter(cmd,"@pGroupIDs",System.Data.DbType.String); db.SetParameterValue(cmd,"1,4"); IDataReader reader = db.ExecuteReader(cmd); DropDownListRole.DataTextField = "Group"; DropDownListRole.DataValueField = "ID"; while (reader.Read()) { DropDownListRole.Items.Add((new ListItem(reader[1].ToString(),reader[0].ToString()))); } reader.Close(); } 这是我的程序: CREATE Procedure [dbo].[sp_getUserRoles](@pGroupIDs varchar(50)) AS BEGIN SELECT * FROM CheckList_Groups Where id in (@pGroupIDs) END 解决方法
这是我发现要做的事情的解决方法
CREATE Procedure [dbo].[sp_getUserRoles]( @pGroupIDs varchar(50) ) As BEGIN SELECT * FROM CheckList_Groups Where (',' + @pGroupIDs +',' LIKE '%,' + CONVERT(VARCHAR,id) + ',%') End 这将获得逗号分隔列表并将其与使用LIKE的表中的id(表示为’,1,’,’等)进行比较 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc – 使用ASP.NET MVC /实体框架对POCO验证的建议
- asp.net-mvc – 将焦点放在不使用JavaScript的EditorFor上
- asp.net-mvc-3 – MVC按钮点击动作
- 单元测试Raven和ASP.NET成员资格
- asp.net-mvc – 从ASP.NET MVC2升级到MVC3的原因
- macos – ASP.NET CORE 2.1预览“Csc”任务不支持“SharedC
- asp.net – 如何连接RDLC表达式中的值?
- asp.net – DataSet.GetXml没有返回null结果
- asp.net – 改进MonoRail
- 如何在asp.net中检测新的Microsoft浏览器“Edge”
推荐文章
站长推荐
热点阅读