最近一直在用,也一直在学oralc,项目上也用到了批量的添加(读取上传CSV文件信息,把符合条件的信息写入到数据库中),在写的时候想到了可能是数据量大就想该怎么快,(由于本人在.NET开发期间没有做过深度的优化)

     private string GUID;//序号GUID唯一标识
private string filename;//文件名称
private string lmportl_ID;//导入ID
private Int32? lmportl_date;//导入时间
private string diflag;// 国际/国内标识 DIFlag

上传CSV文件有专门的方法,只要复制进去就好了

  

   #region 将CSV文件的数据读取到DataTable中
/// <summary>
/// 将CSV文件的数据读取到DataTable中
/// </summary>
/// <param name="fileName">CSV文件路径</param>
/// <returns>返回读取了CSV数据的DataTable</returns>
public static DataTable OpenCSV(string filePath)
{
DataTable dt = new DataTable();
FileStream fs = new FileStream(filePath, System.IO.FileMode.Open, System.IO.FileAccess.Read); StreamReader sr = new StreamReader(fs, Encoding.UTF8);
//StreamReader sr = new StreamReader(fs, encoding);
//string fileContent = sr.ReadToEnd();
//记录每次读取的一行记录
string strLine = "";
//记录每行记录中的各字段内容
string[] aryLine = null;
string[] tableHead = null;
//标示列数
int columnCount = ;
//标示是否是读取的第一行
bool IsFirst = true;
//逐行读取CSV中的数据
while ((strLine = sr.ReadLine()) != null)
{ if (IsFirst == true)
{
tableHead = strLine.Split(','); if (tableHead.Length > )
//截取列数
tableHead = tableHead.Skip().Take().ToArray();
IsFirst = false;
columnCount = tableHead.Length; //创建列
for (int i = ; i < columnCount; i++)
{
tableHead[i] = tableHead[i].Replace("\"", "");
DataColumn dc = new DataColumn(tableHead[i]);
dt.Columns.Add(dc);
}
}
else
{
aryLine = strLine.Split(',');
if (aryLine.Length > )
aryLine = aryLine.Skip().Take().ToArray();
DataRow dr = dt.NewRow();
//是否超过1000行
if (dt.Rows.Count <= )
{
//Prefix和FormType字符串长度是否超过3
if (aryLine[].Length <= && aryLine[].Length <= )
{
dr[] = aryLine[].Replace("\"", "");
dr[] = aryLine[].Replace("\"", "");
}
else
{
dr[] = aryLine[].Substring(, );
dr[] = aryLine[].Substring(, );
}
//TicketNo 字符串长度是否超过8
if (aryLine[].Length <= )
{
dr[] = aryLine[].Replace("\"", "");
}
else
{
dr[] = aryLine[].Substring(, );
}
}
else
{
return dt;//跳出程序,行数大于1000,不做添加,
}
dt.Rows.Add(dr);
}
}
if (aryLine != null && aryLine.Length > )
{
dt.DefaultView.Sort = tableHead[];
}
sr.Close();
fs.Close();
return dt;
}
#endregion

上传完成的CSV文件返回的DataTable  我需要把DataTable 转货成List,我们用的EF所以可以直接转换

  DataEnt = DataConvertor.GetEntityList<t>(dtb) as List<T>;

把List传入方法中

   #region 插入票号转换数据到表
/// <summary>
/// 插入票号转换数据到表
/// </summary>
/// <param name="">表的实体</param>
/// <returns></returns>
public BaseEntityJsonObject<int> Insert_TRANSFER(List<T> T)
{ BaseEntityJsonObject<int> result = new BaseEntityJsonObject<int>();
int count = ;
string strSql = "";
try
{
StringBuilder strBuilder = new StringBuilder(); strBuilder.Append("INSERT INTO 表名( 字段明,字段明,字段明) ");
strBuilder.Append("select sequence_name.nextval ,t.c1,t.c2,t.c3,t.c4,t.c5 FROM ( ");
foreach (var item in T)
{
strBuilder.Append(" SELECT ");
strBuilder.Append("'" + item.字段名+ " 'C1,'" + item.字段名+ " 'C2,'" + item.字段名+ "' C3,");
strBuilder.Append("'字段名' C4 ,'" + 字段名+ "' C5 FROM DUAL union all ");
}
strBuilder.Append(" ) T");
strSql = string.Format(strBuilder.ToString());
int i = ;
//sql写完后这里嘚坐sql的截取,要不然会报错
strSql = strSql.Remove(strSql.Length - i, ); count = DbContext.Database.ExecuteSqlCommand(strSql); }
catch (Exception ex)
{
ExceptionHandler.HandleException(ex); }
return result;
}
#endregion

这就是添加!

下面写批量修改

写修改前先要把要修稿的数据查询出来,转货成LIst,我就不说怎么查询,怎么转货List了

我这里写的流程是先把List写进数据库的视图中,然后数据插进伪表中 然后根据伪表中的数据做进一步的条件,不说了,直接上代码

        #region 修改转换数据到表
/// <summary>
/// 修改转换数据到表
/// </summary>
/// <param name="">表的实体</param>
/// <returns></returns>
public BaseEntityJsonObject<int> Update_TRANSFER(List<T> T)
{
BaseEntityJsonObject<int> result = new BaseEntityJsonObject<int>();
int count = ;
string strSql = "";
try
{
StringBuilder strBuilder = new StringBuilder();
strBuilder.Append(" MERGE INTO TRT_TICKETNUMBER_TRANSFER T1 USING ( ");
//从这里循环要修改的数据,把数据先临时放到伪表中
foreach (var item in t)
{
strBuilder.Append(" SELECT '" + item.要修改的字段名+ "' a, '" + item.要修改的字段名+ "' b FROM DUAL t ");
strBuilder.Append(" union all ");
}
string str2 = strBuilder.ToString();
if (str2 != "")
{
str2 = str2.Remove(str2.Length - );
}
//把sql进行截取,要不然会报错,然后在拼接SQL语句 StringBuilder strBuilder2 = new StringBuilder();
strBuilder2.Append(" ) T2 ON ( T1.表中的主键字段 = T2.a 临时表的字段 ) ");
strBuilder2.Append(" WHEN MATCHED THEN ");
strBuilder2.Append(" UPDATE SET T1.需要修改的字段名 = t2.b"); strSql = str2 + strBuilder2.ToString();
count = DbContext.Database.ExecuteSqlCommand(strSql);
result.payload = count;
result.errorCode = ;
}
catch (Exception ex)
{
ExceptionHandler.HandleException(ex); LogHelper.Error(string.Format("添加表数据失败"), ex);
}
return result;
}
#endregion

这样就完成了数据的修改,

由于临时想起来写博客,没有准备充分,

有什么不妥的欢迎大家指出,欢迎大家吧问题指出来,然后大家共同进步

Oracl 一条sql语句 批量添加、修改数据的更多相关文章

  1. ASP.NET MVC用存储过程批量添加修改数据

    用Entity Framework 进行数据库交互,在代码里直接用lamda表达式和linq对数据库操作,中间为程序员省去了数据库访问的代码时间,程序员直接可以专注业务逻辑层的编写.但是对于比较复杂的 ...

  2. .net Sql语句批量插入数据库数据

    #region 使用SqlBulkCopy public static bool ExecuteTransactionScopeInsert(DataTable dt, int batchSize) ...

  3. JavaWeb 学习009-4个页面,5条sql语句(添加、查看、修改、删除)

    ===========++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++==+++++++++ 2016-12-3------ ...

  4. JavaWeb 学习007-4个页面,5条sql语句(添加、查看、修改、删除)2016-12-2

    需要复习的知识: 关联查询 =================================================================================班级模块学 ...

  5. SQL语句的添加、删除、修改多种方法

    SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作╔------- ...

  6. 转 SQL语句的添加、删除、修改多种方法

    SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作 ╔------ ...

  7. Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例

    如何用一条sql语句实现批量更新?mysql并没有提供直接的方法来实现批量更新,但是可以用点小技巧来实现. 复制代码 代码如下: UPDATE mytable SET myfield = CASE i ...

  8. (七)修改上一条SQL语句,NULL值的滤空函数nvl

    修改上一条SQL语句 1.用c命令来修改(c 即 change ) 默认,光标闪烁位置指向上一条SQL语句的第一行.输入二则定位到第二行. c /错误的关键字/正确的关键字 SQL form emp; ...

  9. java执行多条SQL语句

    一次执行多条SQL的技术要点如下: DatabaseMetaData接口是描述有关数据库的整体综合信息,由于DatabaseMetaData是接口,所以没有构造方法,故不能使用new来创建Databa ...

随机推荐

  1. 一、Java 23 种设计模式简介

    一.23种设计模式分类: 二.设计模式的六大原则: 1.开闭原则(Open Close Principle):对扩展开放,对修改关闭.在程序需要进行拓展的时候,不能去修改原有的代码,实现一个热插拔的效 ...

  2. HTML 练习拖动面板

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. (四)图数据neo4j用户管理

    1.用户管理 neo4j可通过内置函数,进行用户的创建.查看.删除. (1)用户创建; CALL dbms.security.createUser(name,password,requridchang ...

  4. SQLsever存储过程分页查询

    使用存储过程实现分页查询,SQL语句如下: USE [DatebaseName] --数据库名 GO /****** Object: StoredProcedure [dbo].[Pagination ...

  5. 常见hash算法

    hash算法的意义在于提供了一种快速存取数据的方法,它用一种算法建立键值与真实值之间的对应关系,(每一个真实值只能有一个键值,但是一个键值可以对应多个真实值),这样可以快速在数组等条件中里面存取数据. ...

  6. Kafka 消费者相关配置

    消费者相关配置类为  org.apache.kafka.clients.consumer.ConsumerConfig 具有以下配置参数 1. GROUP_ID_CONFIG = "grou ...

  7. Servlet+JSP及Tomcat常见面试题(面试必备)

    1.  什么是servlet? servlet是用来处理客户端请求并产生动态网页内容的java类 2.  Tomcat的缺省端口是多少,怎么修改? a)      默认端口号是8080 b)      ...

  8. 【Python语言】--Crontab结合Python脚本实现将日志每天写入到文件中

    一.前述 实际工作中将Python脚本每天定时写入到日志文件中的使用场景还是蛮多的,有很多种方法可以实现这种效果.本文选择一种方式实现,特将实现细节做如下分享,不当之处烦请指正. 二.具体 1.pyt ...

  9. 程序员也想改 Lottie 动画?是的!

    一.前言 Hi,大家好,我是承香墨影! Lottie 是 Airbnb 开源的一套跨平台的完整的动画效果解决方案,用过都说好.完全解耦开发人员和设计师,让设计师设计的动画,在程序中无缝还原,真是一旦拿 ...

  10. 高效并发unsafe-星耀

    定义 Unsafe类是在sun.misc包下,不属于Java标准.但是很多Java的基础类库,包括一些被广泛使用的高性能开发库都是基于Unsafe类开发的,比如Netty.Cassandra.Hado ...