c# mysql参数化查询_C#参数化SQL查询

public static IDataReader ExecuteReader(DbCommand comm, string sql, params object[] value)

{

comm.CommandText=sql;if (value != null && value.Length >= 0)

{if (comm.CommandText.IndexOf("?") == -1)

{string[] temp = sql.Split('@');for (int i = 0; i < value.Length; i++)

{stringpName;if (temp[i + 1].IndexOf(" ") > -1)

{

pName= "@" + temp[i + 1].Substring(0, temp[i + 1].IndexOf(" "));

}else{

pName= "@" + temp[i + 1];

}//pName = "@p" + (i + 1).ToString();

DbParameter p =comm.CreateParameter();

p.DbType=DbType.String;

p.ParameterName=pName;

p.Value=value[i];

comm.Parameters.Add(p);

}

}else{string[] temp = sql.Split('?');for (int i = 0; i < value.Length; i++)

{

temp[i]= temp[i] + "@p" + (i + 1).ToString();string pName = "@p" + (i + 1).ToString();

DbParameter p=comm.CreateParameter();

p.DbType=DbType.String;

p.ParameterName=pName;

p.Value=value[i];

comm.Parameters.Add(p);

}

StringBuilder sb= newStringBuilder();for (int i = 0; i < temp.Length; i++)

{

sb.Append(temp[i]);

}

comm.CommandText=sb.ToString();

}

}if (comm.Connection.State !=ConnectionState.Open)

{

comm.Connection.Open();

}returncomm.ExecuteReader(CommandBehavior.CloseConnection);

}

调用的时候类似:ExecuteReaderParams(comm,"select * from xx where id=? and name=?",id,name);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值