青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 298  文章 - 377  trackbacks - 0
<2008年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(34)

隨筆分類

隨筆檔案

文章檔案

相冊

收藏夾

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

select * from OpenRowset('MSDASQL', 'Driver={Microsoft Text Driver (*.txt; *.csv)};DefaultDir=C:\Users\Administrator\Desktop;','select * from Num.txt') 
select * from opendatasource('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=C:\Users\Administrator\Desktop')...[Num.txt]
BULK INSERT master..Temp FROM 'C:\Users\Administrator\Desktop\Num.txt' WITH  ( FIELDTERMINATOR =' ', ROWTERMINATOR= '\n') 

/** 導入文本文件
EXEC master..xp_cmdshell 'bcp dbname..tablename in c:\DT.txt -c -Sservername -Usa -Ppassword'
 
/** 導出文本文件
EXEC master..xp_cmdshell 'bcp dbname..tablename out c:\DT.txt -c -Sservername -Usa -Ppassword'

EXEC master..xp_cmdshell 'bcp "Select * from dbname..tablename" queryout c:\DT.txt -c -Sservername -Usa -Ppassword'
 
導出到TXT文本,用逗號分開
exec master..xp_cmdshell 'bcp "庫名..表名" out "d:\tt.txt" -c -t ,-U sa -P password'

在做一些web數據庫管理系統的時候經常要實現將帳戶批量注冊的功能,今天就來講講如何在C#-web項目中將txt文件和excel文件導入SQL2000數據庫。
1.數據庫準備
在SQL2000數據庫的實例數據庫pubs中建立一個數據表txtInsert,字段很簡單:id,name兩個。
2.txt文本文件導入
對于數據文件導入與導出SQL2000提供了BULK INSERT和BCP語句,在這里可以使用BULK INSERT命令實現。假設在c盤上有一個文本文件stu.txt內容為:
    1,tom
    2,jack
    3,jhon
    ......
實現導入的C#代碼如下:
protected System.Web.UI.HtmlControls.HtmlInputFile fName;  
protected System.Web.UI.WebControls.Button BtnInsert;
//上面兩個控件自己添加
private void BtnInsert_Click(object sender, System.EventArgs e)
  
{
                
string fPath=this.fName.PostedFile.FileName;//獲得要導入的文本文件                  
            string extName=fPath.Substring(fPath.LastIndexOf(".")+1);//獲得文件的擴展名            
            SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//數據庫連接對象
            con.Open();
            
try
      
{                    
                    SqlCommand com
=new SqlCommand("BULK INSERT pubs.dbo.txtInsert FROM '"+fPath+"' WITH  (FIELDTERMINATOR = ',',ROWTERMINATOR= '\n')",con);
                       
//其中的FIELDTERMINATOR=','指明字段間所使用的分隔符為逗號
                       
//其中ROWTERMINATOR= '\n'指明記錄間所使用的分隔符為回車
                    com.ExecuteNonQuery();
                    Response.Write(
"<script language=javascript>alert('數據導入成功!')</script>");                    
                }

             
catch (SqlException SQLexc)
                
{
                    Response.Write(
"導入數據庫時出錯:" + SQLexc.ToString());
                }

con.Close();
}

好了,這個txt文件的導入相對簡單,在數據庫中我也沒有設置主鍵,我在里面也沒有加出錯回滾事務操作,在下面的excel文件的導入中介紹。
3.excel文件的導入
在c盤里建立一個stu.xls文件,在sheet1工作表中有兩列數據如下:
     編號  姓名
     1        tom
     2        jack
     3        john
     ......
注意,工作表的第一行是作為標題行的不會被插入到數據庫中,真正導入從第二行開始。
為了演示事物出錯回滾,在這里將txtInsert數據庫表中的id字段設置為主鍵。實現的C#代碼如下:
private void BtnInsert_Click(object sender, System.EventArgs e)
  
{
   
string fPath=this.fName.PostedFile.FileName;//獲得要導入的文本文件     
   string extName=fPath.Substring(fPath.LastIndexOf(".")+1);//獲得文件的擴展名   
   SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//數據庫連接對象
   con.Open();   
    
//注意下面的連接字符串,是它起到了導入的作用
    SqlCommand excelCmd=new SqlCommand("insert into txtInsert select * from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 5.0;HDR=YES;DATABASE="+fPath+"',Sheet1$)",con);
    SqlTransaction myTran
=con.BeginTransaction();//開始一個事務操作
    excelCmd.Transaction=myTran;
    
try
    
{       
     excelCmd.ExecuteNonQuery();
     myTran.Commit();
//提交事務       
     Response.Write("<script language=javascript>alert('數據導入成功!')</script>");
    }

    
catch (SqlException err)
    
{       
     myTran.Rollback(); 
//出錯回滾事務操作
     
//以下三行是去掉數據庫出錯信息中的非法字符單引號、回車和換行符,否則在使用時javascript代碼將有語法錯誤
     
//因為js的編碼和c#的編碼不同
     string errString=err.Message.Replace("'"," ");
     errString
=errString.Replace(Convert.ToChar(13).ToString(),"");
     errString
=errString.Replace(Convert.ToChar(10).ToString(),"");
     
//顯示出錯信息框
     Response.Write("<script language=javascript>alert('導入數據庫時出錯!詳細信息:"+errString+"')</script>");         
    }
   
   con.Close();
  }
這里“顯示出錯信息框”開始我沒有田間那三行代碼,結果搞了半天,最后還是在html文件中發現javascript代碼部分出現了分行,老是提示“未結束的字符串常量”,所以導致不能打開信息框,郁悶死我了,花了好多時間。
4.將excel中部分列導入數據庫的方法
上面講了關于將整個excel文件導入數據庫的方法,那么在實際項目中遇到將excel文件中若干列導入數據庫怎么辦的呢,原理差不多,我就將代碼直接給出了:
                   string  fPath=this.fName.PostedFile.FileName;//獲得要導入的文本文件     
                   string  extName=fPath.Substring(fPath.LastIndexOf(".")+1);//獲得文件的擴展名   
                   SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//數據庫連接對象
                   con.Open();                
                   string mystring="Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = '"+fPath+"';Extended Properties=Excel 8.0";
                OleDbConnection cnnxls 
= new OleDbConnection (mystring);
                OleDbDataAdapter myDa 
=new OleDbDataAdapter("select * from [Sheet1$]",cnnxls);
                DataSet myDs 
=new DataSet();
                myDa.Fill(myDs);
                
if(myDs.Tables[0].Rows.Count > 0)
                
{
                    
string strSql = "";
                    
string CnnString="Provider=SQLOLEDB;database=pubs;server=.;uid=sa;pwd=";
                    OleDbConnection conn 
=new OleDbConnection(CnnString);
                    conn.Open ();
                    OleDbCommand myCmd 
=null;                    
                    
for(int i=0; i<myDs.Tables[0].Rows.Count;i++)//第一個工作表中行數,不包括第一行,
                    {
                        
strSql="insert into txtInsert(id,name) values (";
                        strSql 
+= myDs.Tables[0].Rows[i].ItemArray[0].ToString() + ", '";
                        strSql 
+= myDs.Tables[0].Rows[i].ItemArray[1].ToString() + "')";
                        myCmd
=new OleDbCommand(strSql,conn);
                        
try
                        
{                            
                            myCmd.ExecuteNonQuery();                                                        
                            Response.Write(
"<script language=javascript>alert('數據導入成功!')</script>");
                        }

                        
catch (OleDbException err)
                        
{                                                       
                            Response.Write(
"導入數據庫時出錯:" +err.ToString());
                            
break;
                        }

                    }

                    conn.Close();
其他部分代碼自己加吧,這里就是出錯失誤回滾有點不好處理,請高手指教??!
posted on 2013-03-18 21:11 聶文龍 閱讀(1543) 評論(0)  編輯 收藏 引用 所屬分類: Database 、Visual C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产一区二区久久| 亚洲国产精品久久久久婷婷老年 | 久久精品日韩一区二区三区| 亚洲欧美激情一区二区| 亚洲图片欧美一区| 亚洲综合色视频| 性欧美xxxx视频在线观看| 欧美一级在线亚洲天堂| 久久国产精品久久w女人spa| 久久精品91久久香蕉加勒比 | 亚洲精品资源| 99在线精品观看| 亚洲一区二区欧美日韩| 亚洲一区视频| 欧美专区亚洲专区| 麻豆成人在线| 亚洲国产美女精品久久久久∴| 欧美激情日韩| aa级大片欧美| 亚洲欧美另类国产| 久久久久91| 欧美精品一区三区在线观看| 国产精品www994| 国产亚洲一区二区在线观看| 亚洲第一页自拍| 一区二区三区欧美激情| 午夜亚洲视频| 欧美不卡一区| 99国产一区二区三精品乱码| 亚洲欧美成人一区二区在线电影| 久久精品视频va| 欧美国产日韩一区二区在线观看| 欧美三级韩国三级日本三斤| 国产精品区一区二区三区| 极品少妇一区二区三区精品视频 | 男人插女人欧美| 亚洲精品美女在线观看播放| 亚洲一区二区三区在线观看视频| 久久另类ts人妖一区二区| 欧美日韩国产色视频| 国产欧美日韩三级| 亚洲精品久久久蜜桃| 亚洲欧美日韩另类精品一区二区三区 | 亚洲视频欧美视频| 久久久久**毛片大全| 欧美日韩精品免费看| 狠狠噜噜久久| 亚洲在线一区二区| 欧美成人免费全部观看天天性色| 99视频在线观看一区三区| 久久久久久久久久久一区| 欧美日韩日本网| 亚洲第一天堂无码专区| 亚洲欧美怡红院| 亚洲第一在线视频| 欧美一区二区三区啪啪| 欧美日韩精品| 亚洲国产高清一区| 欧美在线三区| 一本久道综合久久精品| 另类国产ts人妖高潮视频| 国产老女人精品毛片久久| 亚洲精品在线二区| 蜜臀久久久99精品久久久久久| 一区二区高清| 欧美成人日韩| 尤物网精品视频| 久久国产精品网站| 一本色道久久综合| 欧美国产日本在线| 在线观看成人一级片| 欧美影院在线播放| 9色国产精品| 免费h精品视频在线播放| 亚洲伊人伊色伊影伊综合网 | 免费成人黄色av| 亚洲图中文字幕| 欧美日本国产一区| 亚洲精品久久久久| 免费在线成人av| 欧美在线视频日韩| 国产裸体写真av一区二区| 亚洲一区影院| 亚洲伦伦在线| 欧美日韩高清在线一区| 亚洲黑丝在线| 欧美h视频在线| 久久久久久久综合色一本| 国产在线不卡| 久久久久高清| 欧美在线免费一级片| 国产日韩欧美亚洲一区| 欧美一级播放| 亚洲欧美国产制服动漫| 国产精品一区二区三区免费观看| 亚洲调教视频在线观看| av72成人在线| 欧美午夜视频在线| 亚洲欧美日韩精品久久| 亚洲一区二区网站| 国产精品综合av一区二区国产馆| 亚洲欧美一区二区视频| 亚洲男人的天堂在线aⅴ视频| 国产精品久久久久久久午夜| 亚洲在线免费| 亚洲淫性视频| 国产一区二区三区视频在线观看| 久久久精品日韩欧美| 久久黄色级2电影| 136国产福利精品导航| 欧美丰满高潮xxxx喷水动漫| 欧美成人免费小视频| 一本久道久久综合中文字幕| 99亚洲精品| 国产欧美va欧美va香蕉在| 久久九九国产精品| 美女国产一区| av不卡在线观看| 亚洲一区3d动漫同人无遮挡| 国产区在线观看成人精品| 久久在精品线影院精品国产| 久久综合成人精品亚洲另类欧美| 亚洲日本无吗高清不卡| 日韩香蕉视频| 国产一区二区三区无遮挡| 久久亚洲免费| 欧美精品久久久久a| 亚洲一区网站| 久久久久国产精品www| 亚洲精品日日夜夜| 亚洲一区二区三区视频| 一区二区三区无毛| 亚洲另类在线视频| 国产美女诱惑一区二区| 美女成人午夜| 欧美三区在线视频| 久久米奇亚洲| 欧美久久电影| 久久久久久久久久看片| 男人插女人欧美| 亚洲欧美精品中文字幕在线| 久久久久久穴| 亚洲视频免费在线| 欧美一区激情视频在线观看| 亚洲美女av电影| 午夜视频在线观看一区| 亚洲靠逼com| 香港久久久电影| 99热精品在线观看| 欧美一区二区三区在线| 亚洲看片一区| 久久精品视频亚洲| 亚洲综合第一| 久久亚洲国产成人| 欧美在线精品一区| 欧美国产极速在线| 久久精品国产在热久久 | 亚洲一区二区三区午夜| 久久免费黄色| 亚洲欧美国产一区二区三区| 裸体女人亚洲精品一区| 欧美一级在线视频| 欧美另类高清视频在线| 玖玖精品视频| 国产欧美精品日韩区二区麻豆天美| 欧美福利网址| 国产午夜精品一区二区三区视频| 亚洲人成7777| 在线日韩av永久免费观看| 午夜精品亚洲一区二区三区嫩草| 日韩亚洲欧美中文三级| 久久噜噜亚洲综合| 欧美与欧洲交xxxx免费观看 | 久久青青草综合| 欧美一区二区私人影院日本| 欧美日韩国产小视频| 欧美激情第五页| 国产在线观看一区| 亚洲一区日韩| 亚洲永久精品大片| 欧美激情在线狂野欧美精品| 美女脱光内衣内裤视频久久影院| 国产精品一区二区久久久| 一区二区久久久久| 9人人澡人人爽人人精品| 欧美成人高清| 欧美风情在线观看| 1769国产精品| 久久久久网址| 麻豆成人综合网| 黄色成人在线| 久久精品91久久久久久再现| 欧美亚洲尤物久久| 国产精品人人爽人人做我的可爱| 日韩一级在线观看| 一区二区三区蜜桃网| 欧美日韩三区四区| 99国产麻豆精品| 亚洲午夜激情网页| 国产精品久久波多野结衣|