c#批量更新list对象sql
注意:
1.语句中"set "后有空格,
2.最后一个if一定有值,且接连的sql字段 无 逗号
3.parameterList.Clear();
/// <summary>
/// 批量更新
/// </summary>
public void UpdateList(List<ProModule.Model.ept_scn> list)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("update ept_scn set ");
List<MySqlParameter> parameterList = new List<MySqlParameter>();
int x = list.Count;
Hashtable SQLStringList = new Hashtable();
for (int i = 0; i < x; i++)
{
ProModule.Model.ept_scn scn = list[i];
int y = 0;
if (scn.scn != null)
{
strSql.Append("scn=@scn,");
parameterList.Add(new MySqlParameter("@scn", MySqlDbType.VarChar, 50));
parameterList[y].Value = scn.scn;
y = y + 1;
}
if (scn.is_lock != null)
{
strSql.Append("is_lock=@is_lock,");
parameterList.Add(new MySqlParameter("@is_lock", MySqlDbType.Int32, 11));
parameterList[y].Value = scn.is_lock;
y = y + 1;
}
if (scn.is_audit != null)
{
strSql.Append("is_audit=@is_audit,");
parameterList.Add(new MySqlParameter("@is_audit", MySqlDbType.Int32, 11));
parameterList[y].Value = scn.is_audit;
y = y + 1;
}
if (scn.is_abandon != null)
{
strSql.Append("is_abandon=@is_abandon,");
parameterList.Add(new MySqlParameter("@is_abandon", MySqlDbType.Int32, 11));
parameterList[y].Value = scn.is_abandon;
y = y + 1;
}
if (scn.is_finish != null)
{
strSql.Append("is_finish=@is_finish,");
parameterList.Add(new MySqlParameter("@is_finish", MySqlDbType.Int32, 11));
parameterList[y].Value = scn.is_finish;
y = y + 1;
}
if (scn.remark != null)
{
strSql.Append("remark=@remark,");
parameterList.Add(new MySqlParameter("@remark", MySqlDbType.VarChar, 50));
parameterList[y].Value = scn.remark;
y = y + 1;
}
if (scn.msg != null)
{
strSql.Append("msg=@msg,");
parameterList.Add(new MySqlParameter("@msg", MySqlDbType.VarChar, 50));
parameterList[y].Value = scn.msg;
y = y + 1;
}
if (scn.audit_by != null)
{
strSql.Append("audit_by=@audit_by,");
parameterList.Add(new MySqlParameter("@audit_by", MySqlDbType.VarChar, 50));
parameterList[y].Value = scn.audit_by;
y = y + 1;
}
if (scn.audit_time != null)
{
strSql.Append("audit_time=@audit_time,");
parameterList.Add(new MySqlParameter("@audit_time", MySqlDbType.DateTime));
parameterList[y].Value = scn.audit_time;
y = y + 1;
}
if (scn.checks != null)
{
strSql.Append("checks=@checks");
parameterList.Add(new MySqlParameter("@checks", MySqlDbType.Int32, 11));
parameterList[y].Value = scn.checks;
y = y + 1;
}
strSql.Append(" where id=@id ");
parameterList.Add(new MySqlParameter("@id", MySqlDbType.VarChar, 50));
parameterList[y].Value = scn.id;
MySqlParameter[] parameters = parameterList.ToArray(); ;
SQLStringList.Add(strSql.ToString(), parameters);
parameterList.Clear();
}
DbHelperMySQL.ExecuteSqlTran(SQLStringList);
}
c#批量更新list对象sql的更多相关文章
- 批量更新数据小心SQL触发器的陷阱
批量更新数据时候,Inserted和Deleted临时表也是批量的,但触发器只会调用执行一次!两个概念千万不要弄混淆! 错误的理解:例如:创建在A表上创建了一个Update触发器,里面写的是Updat ...
- Hibernate批量更新和批量删除批量添加(转)
通常,在一个Session对象的缓存中只存放数量有限的持久化对象,等到Session对象处理事务完毕,还要关闭Session对象,从而及时释放Session的缓存占用的内存.批量处理数据是指在一个事务 ...
- druid + mysql + mybatis 批量更新报错
首先 批量更新报错 sql injection violation, multi-statement not allow 然后看了博客:https://blog.csdn.net/qq_3634595 ...
- LINQ To SQL在N层应用程序中的CUD操作、批量删除、批量更新
原文:LINQ To SQL在N层应用程序中的CUD操作.批量删除.批量更新 0. 说明 Linq to Sql,以下简称L2S. 以下文中所指的两层和三层结构,分别如下图所示: 准确的说,这里 ...
- SQL 将2张不相关的表拼接成2列,批量更新至另一张表
update SO_Master set LotteryNo=t2.LotteryNo,UpdateTime=GETDATE() --select sm.LotteryNo,sm.SysNo,t2.L ...
- SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int
--SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int --关键说明:--1.从系统表syscolumns中的查询所有xtype='48'的记录得到类型为[tinyint]的字段- ...
- 高效批量更新 sql 字段的值(从一个表向另一个表更新)
里给出一种更高效.简洁的做法,批量更新SQL ,一句SQL就可以替代麻烦的循环过程,有MS SQLServer.Oracle.DB2下的写法--关键点:t4和t1是同一个table,primary k ...
- mybatis 的批量更新操作sql
转: mybatis 的批量更新操作sql 2018年07月23日 10:38:19 海力布 阅读数:1689 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.cs ...
- SQL批量更新数据
SQL批量更新数据 step1:导入Excel数据, 具体见百度.注意点:一列中含有float型数据和文本数据的时候,导入要将Excel中的表格属性改成文本,或在数字项目前加个单引号. step2 ...
随机推荐
- Java file方法的路径特性
1.在flle方法里,直接写空白的路径,是会默认获取当前Java编译工作空间的路径. 例子如下: package example_1; import java.io.File; import java ...
- 使用SQL SERVER PIVOT实现行列转置
一般我们在使用SQL语句实现行列转置时候,最常用的方法无外乎就是 case语句来实现,但是如果需要需要转置的列太多,那么case起来语句就无限庞大,十分不方便,sql server中的PIVOT就可以 ...
- Mac技巧之苹果电脑Mac OS X系统自带的鼠标所在点颜色RGB值查看工具:数码测色计
转自http://www.mac52ipod.cn/post/show-mouse-point-rgb-color-by-apple-mac-os-x-tool.php
- hive 动态分区实现 (hive-1.1.0)
笔者使用的hive版本是hive-1.1.0 hive-1.1.0动态分区的默认实现是只有map没有reduce,通过执行计划就可以看出来.(执行计划如下) insert overwrite tabl ...
- Dagger2使用
初衷 Dagger2的初衷就是通过依赖注入让你少些很多公式化代码,更容易测试,降低耦合,创建可复用可互换的模块.你可以在Debug包,测试运行包以及release包优雅注入三种不同的实现. 依赖注入 ...
- Centos 7上安装Elasticsearch
1. 先安装jdk yum search java|grep jdk查看yum库中都有哪些jdk版本 yum install java-1.8.0-openjdk.x86_64 两次y确认 2. ce ...
- Vim 常用命令和编辑方法
命令模式 :e <path/to/file> → 打开一个文件 :w → 存盘 :wq → 存盘 + 退出 (:w 存盘, :q 退出) (陈皓注::w 后可以跟文件名) :savea ...
- 机器学习进阶-直方图与傅里叶变换-图像直方图 1.cv2.calc(生成图像的像素频数分布(直方图))
1. cv2.calc([img], [0], mask, [256], [0, 256]) # 用于生成图像的频数直方图 参数说明: [img]表示输入的图片, [0]表示第几个通道, mask表 ...
- day13-文件操作
1.打开与关闭 1.1.open() close()我们使用 open() 函数打开文件.这个函数将返回一个文件对象,我们对文件的读写都将使用这个对象.open() 函数需要三个参数,第一个参数是文件 ...
- BBS--首页、个人站点、ORM
首页 首页文章排版渲染 登录不登录两种情况 1.bootstrap导航条 点击session 创建登陆后创建人物图表 bootstrap--样式 <li><a href=" ...