SQLParameter[]安全传值 和 DataTable与List<T>的运用

本文介绍了一种从DataTable转换数据到List&lt;T&gt;的方法,并提供了一个具体的Category类实例。此外,还展示了如何通过参数化查询来安全地执行SQL更新操作。
将DataTable中的数据装到List<T>中
 
/// <summary>
        
/// 返回所有类别集合
        
/// </summary>
        
/// <returns></returns>
        public List<Category> Select()
        {
            List
<Category> list = new List<Category>();
            
string sql = "select id,caname,pid from nn_category";
            DataTable dt 
= helper.ExecuteQuery(sql);
            
foreach (DataRow row in dt.Rows)
            {
                
string id = row[0].ToString();
                
string caname = row[1].ToString();
                
string pid = row[2].ToString();
                list.Add(
new Category() { Id = id, Caname = caname, Pid = pid });
            }
            
return list;
        }

 

将值安全的传到SQL语句中执行

 

/// <summary>
        
/// 修改分类
        
/// </summary>
        
/// <param name="id">要修改的ID</param>
        
/// <param name="pid">修改后的分类父ID</param>
        
/// <returns></returns>
        public bool Update(string id, string pid)
        {
            
string sql = "update nn_category set pid=@pid where id=@id";
            SQLParameter[] paras 
= new SQLParameter[]{
                   
new SQLParameter("@id",(id as object)),
                   
new SQLParameter("@pid",(pid as object)) 
            };
            
return helper.ExecuteNonQuery(sql, paras);
        }

 

 

转载于:https://www.cnblogs.com/kingfly/archive/2010/01/16/1649780.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值