久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

如何在DELPHI中將EXCEL中的數(shù)據(jù)導(dǎo)入到SQL數(shù)據(jù)庫(kù) - 漂泊在城市邊緣的日志 - ...

 木子示羊 2010-09-06

標(biāo)題: 如何在DELPHI中將EXCEL中的數(shù)據(jù)導(dǎo)入到SQL數(shù)據(jù)庫(kù)
關(guān)鍵字: sql
分類: 個(gè)人專區(qū)
密級(jí): 公開(kāi)
(評(píng)分: , 回復(fù): 0, 閱讀: 226) »»
var
  s1:string;
begin
  screen.Cursor:=crSQLWait;
  s1:='insert into table_bus '+
      ' (BS_NO,BS_TYPE,bs_whos,bs_mode,bs_seat,bs_soalseat,bs_drseat,bs_oiltype,bs_buycard,bs_unit,BS_BDATE,bs_edate) '+
      ' SELECT 車號(hào),dbo.uf_GetFullNameCode(車型名稱),dbo.uf_GetFullNameCode(所屬單位),dbo.uf_GetFullNameCode(廠牌型號(hào)),核定座位,售票座位,駕駛室前排座位,dbo.uf_GetFullNameCode(燃料名稱),購(gòu)置證號(hào),本外單位,啟用日期,dbo.uf_ConvertNullDate(終止時(shí)間) '+
      ' FROM OpenDataSource(''Microsoft.Jet.OLEDB.4.0'',''Data Source="'+trim(LabeledEdit1.text)+'";Extended Properties=Excel 8.0;Persist Security Info=False'')...[Sheet1$] '+
      ' where 車號(hào) not in(select bs_no from table_bus) ';
  try
    DataModule1.ADOConnection1.Execute(s1);
  finally
    screen.Cursor:=crArrow;
  end;
end;



  EXCEL是可以當(dāng)成一種數(shù)據(jù)源來(lái)處理的,。  Str := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' + 文件路徑 +
    ';Extended Properties=Excel 8.0;Persist Security Info=False';
然后每列相當(dāng)于一字段  




熟悉SQL SERVER 2000的數(shù)據(jù)庫(kù)管理員都知道,,其DTS可以進(jìn)行數(shù)據(jù)的導(dǎo)入導(dǎo)出,,其實(shí),,我們也可以使用Transact-SQL語(yǔ)句進(jìn)行導(dǎo)入導(dǎo)出操作,。在Transact-SQL語(yǔ)句中,,我們主要使用OpenDataSource函數(shù)、OPENROWSET 函數(shù),,關(guān)于函數(shù)的詳細(xì)說(shuō)明,,請(qǐng)參考SQL聯(lián)機(jī)幫助,。利用下述方法,,可以十分容易地實(shí)現(xiàn)SQL SERVER、ACCESS,、EXCEL數(shù)據(jù)轉(zhuǎn)換,,詳細(xì)說(shuō)明如下:

一,、SQL SERVER 和ACCESS的數(shù)據(jù)導(dǎo)入導(dǎo)出
常規(guī)的數(shù)據(jù)導(dǎo)入導(dǎo)出:
使用DTS向?qū)нw移你的Access數(shù)據(jù)到SQL Server,你可以使用這些步驟:
   ○1在SQL SERVER企業(yè)管理器中的Tools(工具)菜單上,,選擇Data Transformation
   ○2Services(數(shù)據(jù)轉(zhuǎn)換服務(wù)),,然后選擇 czdImport Data(導(dǎo)入數(shù)據(jù))。
   ○3在Choose a Data Source(選擇數(shù)據(jù)源)對(duì)話框中選擇Microsoft Access as the Source,,然后鍵入你的.mdb數(shù)據(jù)庫(kù)(.mdb文件擴(kuò)展名)的文件名或通過(guò)瀏覽尋找該文件,。
   ○4在Choose a Destination(選擇目標(biāo))對(duì)話框中,選擇Microsoft OLE DB Prov ider for SQL Server,,選擇數(shù)據(jù)庫(kù)服務(wù)器,,然后單擊必要的驗(yàn)證方式。
   ○5在Specify Table Copy(指定表格復(fù)制)或Query(查詢)對(duì)話框中,,單擊Copy tables(復(fù)制表格),。
○6在Select Source Tables(選擇源表格)對(duì)話框中,單擊Select All(全部選定),。下一步,,完成。

Transact-SQL語(yǔ)句進(jìn)行導(dǎo)入導(dǎo)出:
1.在SQL SERVER里查詢access數(shù)據(jù):

SELECT *
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\DB.mdb";User ID=Admin;Password=')...表名

2.將access導(dǎo)入SQL server
在SQL SERVER 里運(yùn)行:
SELECT *
INTO newtable
FROM OPENDATASOURCE ('Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\DB.mdb";User ID=Admin;Password=' )...表名

3.將SQL SERVER表里的數(shù)據(jù)插入到Access表中
在SQL SERVER 里運(yùn)行:
insert into OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source=" c:\DB.mdb";User ID=Admin;Password=')...表名
(列名1,列名2)
select 列名1,列名2 from sql表

實(shí)例:
insert into OPENROWSET('Microsoft.Jet.OLEDB.4.0',
'C:\db.mdb';'admin';'', Test)
select id,name from Test


INSERT INTO OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\trade.mdb'; 'admin'; '', 表名)
SELECT *
FROM sqltablename

二,、SQL SERVER 和EXCEL的數(shù)據(jù)導(dǎo)入導(dǎo)出

1,、在SQL SERVER里查詢Excel數(shù)據(jù):

SELECT *
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...[Sheet1$]

下面是個(gè)查詢的示例,它通過(guò)用于 Jet 的 OLE DB 提供程序查詢 Excel 電子表格,。
SELECT *
FROM OpenDataSource ( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

2,、將Excel的數(shù)據(jù)導(dǎo)入SQL server :
SELECT * into newtable
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...[Sheet1$]

實(shí)例:
SELECT * into newtable
FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

3、將SQL SERVER中查詢到的數(shù)據(jù)導(dǎo)成一個(gè)Excel文件
T-SQL代碼:
EXEC master..xp_cmdshell 'bcp 庫(kù)名.dbo.表名out c:\Temp.xls -c -q -S"servername" -U"sa" -P""'
參數(shù):S 是SQL服務(wù)器名,;U是用戶,;P是密碼
說(shuō)明:還可以導(dǎo)出文本文件等多種格式

實(shí)例:EXEC master..xp_cmdshell 'bcp saletesttmp.dbo.CusAccount out c:\temp1.xls -c -q -S"pmserver" -U"sa" -P"sa"'

EXEC master..xp_cmdshell 'bcp "SELECT au_fname, au_lname FROM pubs..authors ORDER BY au_lname" queryout C:\ authors.xls -c -Sservername -Usa -Ppassword'

在VB6中應(yīng)用ADO導(dǎo)出EXCEL文件代碼:
Dim cn As New ADODB.Connection
cn.open "Driver={SQL Server};Server=WEBSVR;DataBase=WebMis;UID=sa;WD=123;"
cn.execute "master..xp_cmdshell 'bcp "SELECT col1, col2 FROM 庫(kù)名.dbo.表名" queryout E:\DT.xls -c -Sservername -Usa -Ppassword'"


4、在SQL SERVER里往Excel插入數(shù)據(jù):

insert into OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
'Data Source="c:\Temp.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...table1 (A1,A2,A3) values (1,2,3)

T-SQL代碼:
INSERT INTO
OPENDATASOURCE('Microsoft.JET.OLEDB.4.0',
'Extended Properties=Excel 8.0;Data source=C:\training\inventur.xls')...[Filiale1$]
(bestand, produkt) VALUES (20, 'Test')

總結(jié):利用以上語(yǔ)句,,我們可以方便地將SQL SERVER,、ACCESS和EXCEL電子表格軟件中的數(shù)據(jù)進(jìn)行轉(zhuǎn)換,為我們提供了極大方便,!




方法2:
procedure TForm1.Button3Click(Sender: TObject);
var
oe:variant;
n1,str:string;
j:integer;
begin
  if opendialog1.Execute then
  opendialog1.DefaultExt:='xls';
  str:=opendialog1.FileName;
  oe:=CreateOleObject('Excel.Application');
  oe.visible:=true;
  oe.workbooks.open(str);
  j:=2;  //假定標(biāo)題在第一行
   try
with adoQuery2 do
   begin
    n1:='select * from ##tbl_cardgrant1 ';
    close;
    sql.Clear;
    sql.Add(n1);
    while oe.worksheets['查詢結(jié)果1'].cells[j,1].text<>'' do
    begin
        for i:=1 to adoquery1.fieldcount do
            Parameters.Items[i-1].Value:=oe.worksheets['查詢結(jié)果1'].cells[j,1].text;
            memo2.Text:=n1;
            execsql;
            j:=j+1;
    end;
oe.visible:=false;
    showmessage('導(dǎo)入完畢');
   end;
   except
     oe.visible:=false;
     showmessage('數(shù)據(jù)庫(kù)錯(cuò)誤或有重復(fù)編號(hào),請(qǐng)檢查');
   end;
end;    

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多