首页 / C# / C# 数据更新(二)
C# 数据更新(二)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C# 数据更新(二),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1503字,纯文字阅读大概需要3分钟。
内容图文
数据更新(二)
将List /HashTable 的数据更新到数据库某一张表中
private bool InsertIntoTable(List<DataModel> models,string conn,string tableName)
{
SqlConnection conn = new SqlConnection(conn);
conn.Open();
SqlTransaction tran = conn.BeginTransaction();
SqlCommand cmd = new SqlCommand(null, conn, tran);
Type type = typeof(DataModel);
System.Reflection.PropertyInfo[] fieldInfos = type.GetProperties();
List<SqlParameter> listSqlParameter = new List<SqlParameter>();
try
{
string fields = string.Empty;
string values = string.Empty;
foreach (var kvp in models)
{
foreach (System.Reflection.PropertyInfo fieldinfo in fieldInfos)
{
var value = fieldinfo.GetValue(kvp, null);
//在这里还可以对不需要插入的字段做限制
if (value == null || tabTable.Columns[fieldinfo.Name] ==null)
{
continue;
}
string strColumnName = "@" + fieldinfo.Name;
fields += fieldinfo.Name + ",";
values += strColumnName + ",";
//针对时间的特殊处理
SqlParameter sqlParameter = new SqlParameter(strColumnName, value);
if (fieldinfo.PropertyType==typeof(DateTime))
{
sqlParameter.DbType = DbType.DateTime;
}
listSqlParameter.Add(sqlParameter);
}
fields = fields.Substring(0, fields.Length - 1);
values = values.Substring(0, values.Length - 1);
string sql = string.Format("Insert into {0} ({1}) values ({2})", tableName, fields, values);
cmd.CommandText = sql;
cmd.Parameters.AddRange(listSqlParameter.ToArray());
cmd.ExecuteNonQuery();
cmd.Parameters.Clear();
}
tran.Commit();
return true;
}
catch (Exception ex)
{
tran.Rollback();
return false;
}
finally
{
conn.Close();
conn.Dispose();
}
}
内容总结
以上是互联网集市为您收集整理的C# 数据更新(二)全部内容,希望文章能够帮你解决C# 数据更新(二)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。