当前位置:编程学习 > C#/ASP.NET >>

向数据库中同时插入多条记录

请问如何在数据库中实现用一条sql语句一次性插入多条记录啊。
麻烦各位大哥帮帮忙。
有实例发我的邮箱 15057149398@163.com 
衷心的感谢大家 --------------------编程问答-------------------- 如果是从一个表插入到另一个表就是 insert into tableA(f1,f2,f3) select f1,f2,f3 from tableB

如果是插入实际的值,就循环插入,或者采用LINQ处理一些类型的数据源 --------------------编程问答-------------------- 对于多条语句组成的sql,每一条语句中间用分号“;”隔开即可。比如说你可以把10个insert语句、20个update语句、再来30个insert语句,以及一条select语句,这样61条sql语句组合在一起,一次性地发送给关系数据库(比如说使用ExecuteReader执行)。中间用分号隔开,是个好习惯。

当然,发送多条sql命令,那么最好要使用 DbTransaction 来控制。因为如果没有这个显式事务,类似sql server这样的系统就会自动为每一条sql语句启动一个事务,这样你就无法保证这61条sql语句统一在一个单独的数据库事务中。 --------------------编程问答-------------------- 每一条语句中间用分号“;”隔开即可  -->  每两条语句中间用分号“;”隔开即可 --------------------编程问答--------------------

    /// <summary>
    /// 带事务的批量操作数据。
    /// </summary>
    /// <param name="sqlInsert">SQL</param>
    /// <returns>操作是否成功</returns>
    public static bool OperateDatasWithTransaction(List<string> sqlList,string flag)
    {
        SqlConnection myConnection = new SqlConnection(ConfigurationManager.ConnectionStrings["SQLCONNECTIONSTRING"].ConnectionString);
        myConnection.Open();
        SqlCommand myCommand = myConnection.CreateCommand();
        SqlTransaction myTrans;
        // Start a local transaction
        myTrans = myConnection.BeginTransaction(IsolationLevel.ReadCommitted);
        // Assign transaction object for a pending local transaction
        myCommand.Connection = myConnection;
        myCommand.Transaction = myTrans;
        try
        {
            foreach (string item in sqlList)
            {
                myCommand.CommandText = item;
                myCommand.ExecuteNonQuery();
            }
            myTrans.Commit();
            return true;
        }
        catch (Exception)
        {
            myTrans.Rollback();
            return false;
        }
        finally
        {
            myConnection.Close();
        }
      }
--------------------编程问答-------------------- 把一条条sql语句放入List<string>中,加上事务,一切ok --------------------编程问答--------------------

/// <summary>
    /// 带事务的批量操作数据。
    /// </summary>
    /// <param name="sqlInsert">SQL</param>
    /// <returns>操作是否成功</returns>
    public static bool OperateDatasWithTransaction(List<string> sqlList)
    {
        SqlConnection myConnection = new SqlConnection(ConfigurationManager.ConnectionStrings["SQLCONNECTIONSTRING"].ConnectionString);
        myConnection.Open();
        SqlCommand myCommand = myConnection.CreateCommand();
        SqlTransaction myTrans;
        // Start a local transaction
        myTrans = myConnection.BeginTransaction(IsolationLevel.ReadCommitted);
        // Assign transaction object for a pending local transaction
        myCommand.Connection = myConnection;
        myCommand.Transaction = myTrans;
        try
        {
            foreach (string item in sqlList)
            {
                myCommand.CommandText = item;
                myCommand.ExecuteNonQuery();
            }
            myTrans.Commit();
            return true;
        }
        catch (Exception)
        {
            myTrans.Rollback();
            return false;
        }
        finally
        {
            myConnection.Close();
        }
      }

多写了个参数,
你这样List<string>L=new List<string>();
L.Add("insert into ......");
......
执行
OperateDatasWithTransaction(L);
即可
--------------------编程问答--------------------
引用 5 楼 hhqsy 的回复:
把一条条sql语句放入List<string>中,加上事务,一切ok



楼上的第二个参数flag,木有用到吧
--------------------编程问答--------------------
引用 7 楼 yanzhiyong 的回复:
引用 5 楼 hhqsy 的回复:
把一条条sql语句放入List<string>中,加上事务,一切ok



楼上的第二个参数flag,木有用到吧
我从我代码弄来的,忘记了处理,看后面的帖子 --------------------编程问答-------------------- 楼上的第二个参数flag,木有用到吧
=================================
已经纠正了 --------------------编程问答-------------------- 谢谢各位高手的解答。
这样循环的在数据库和服务器的进行交互应该很耗资源啊。
我是想能不能要把所有的数据一次性提交到数据库,给数据库处理。也就是服务器和数据库只有一次交互。
这样该怎么实现啊。
--------------------编程问答-------------------- sql语句数组做参数传给存储过程吧
--------------------编程问答--------------------

CREATE function Get_StrArrayLength  (@str varchar(1024),  --要分割的字符串  
 @split varchar(10))  --分隔符号  
 returns int  as 
 begin  
 declare @location int   
 declare @start int   
 declare @length int     
 set @str=ltrim(rtrim(@str))   
 set @location=charindex(@split,@str)   
 set @length=1  
 while @location <>0  
 begin     
 set @start=@location+1    
 set @location=charindex(@split,@str,@start)    
 set @length=@length+1   end   
 return @length 
 end 
--------------
--------------
CREATE function Get_StrArrayStrOfIndex (@str varchar(1024),  --要分割的字符串  
 @split varchar(10),  --分隔符号   
 @index int --取第几个元素 
 )  
returns varchar(1024)  as  
begin   
declare @location int   
declare @start int   
declare @next int   
declare @seed int     
set @str=ltrim(rtrim(@str))   
set @start=1   
set @next=1   
set @seed=len(@split)      
set @location=charindex(@split,@str)   
while @location <>0 and @index>@next   
begin     
set @start=@location+@seed     
set @location=charindex(@split,@str,@start)     
set @next=@next+1   
end   
if @location =0 
select @location =len(@str)+1   --这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。     
 return substring(@str,@start,@location-@start)  
end 
-------------
------------

declare @str varchar(50) 
 set @str='1,2,3,4,5'  
declare @next int    
set @next=1  
while @next <=dbo.Get_StrArrayLength(@str,',') 
 begin   
print dbo.Get_StrArrayStrOfIndex(@str,',',@next)   
set @next=@next+1  
end 

CREATE PROCEDURE [dbo].[sp_Exe_Many]  
@sqls varchar(1000)
as 
declare @next int    
set @next=1  
while @next <=dbo.Get_StrArrayLength(@sqls,',') 
 begin   
 执行 sql语句:dbo.Get_StrArrayStrOfIndex(@sqls,',',@next)   
set @next=@next+1  
end 



--------------------编程问答-------------------- 将整个DataTable或者DataSet一次插入数据库
http://dotnet.aspx.cc/file/Insert-DataSet-Into-Access.aspx --------------------编程问答-------------------- 真晕!

t-sql 本来就可以直接执行客户端传来的多条语句,搞什么“分解”啊?! --------------------编程问答-------------------- 如果是操作不同的表,也可以考虑使用触发器,么有具体遇到问题,提供思路, --------------------编程问答-------------------- 哈哈顶顶
补充:.NET技术 ,  C#
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,