A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 岳喜礼 黑马帝   /  2012-2-2 11:02  /  2589 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 岳喜礼 于 2012-4-18 11:12 编辑

string sql ="update tbTest set colB=@Name,colC=@Sex where id=@ID";

想把参数写到数组里,当做参数传递,如何实现呢?

评分

参与人数 1技术分 +2 收起 理由
朱勋 + 2

查看全部评分

4 个回复

倒序浏览
数组里面存的应该是数据类型相同的数据吧,string sql ="update tbTest set colB=@Name,colC=@Sex where id=@ID";这几个参数的类型不一样吧
回复 使用道具 举报
今天又看了看,可以用 list<T>  还没写好
回复 使用道具 举报
本帖最后由 Suncoder 于 2012-2-13 22:42 编辑

可以用object类型的数组,解决2楼提出的数据类型的问题

----打开数据连接
           object[] listobj = {"name","sex",1};
                    string sql = "update tbTest set colB=@Name,colC=@Sex where id=@ID";
                    cmd.Parameters.Add(new SqlParameter("@Name", listobj[0]));
                    cmd.Parameters.Add(new SqlParameter("@Sex", listobj[1]));
                    cmd.Parameters.Add(new SqlParameter("@ID", listobj[2]));
----执行查询
回复 使用道具 举报
建议楼主看下杨忠科老师asp.net系列中的 ado.net教程 其中涉及到sqlhelper的课程 里面参数化查询利用了foreach语句循环!把sqlparameter作为可变参数数组!!看完你会对可变参数化查询有深刻的了解..不用涉及数组以及list
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马