delphi批量导入数据.docx

上传人:b****8 文档编号:9545874 上传时间:2023-02-05 格式:DOCX 页数:37 大小:484.65KB
下载 相关 举报
delphi批量导入数据.docx_第1页
第1页 / 共37页
delphi批量导入数据.docx_第2页
第2页 / 共37页
delphi批量导入数据.docx_第3页
第3页 / 共37页
delphi批量导入数据.docx_第4页
第4页 / 共37页
delphi批量导入数据.docx_第5页
第5页 / 共37页
点击查看更多>>
下载资源
资源描述

delphi批量导入数据.docx

《delphi批量导入数据.docx》由会员分享,可在线阅读,更多相关《delphi批量导入数据.docx(37页珍藏版)》请在冰豆网上搜索。

delphi批量导入数据.docx

delphi批量导入数据

delphi批量导入数据  

从Excel中导入数据到Access中:

procedureTForm5.Button3Click(Sender:

TObject);//excel导入

var

 EXLfile:

string;

  sheet,XLApp,workbook:

variant;

  iRow,MaxRow:

integer;

begin

 ifopendialog1.Executethen

 begin

   EXLfile:

=opendialog1.FileName;

   screen.Cursor:

=crHourGlass;

   try

    //创建对象

     XLApp:

=createOleObject('Excel.Application');

     XLApp.displayAlerts:

=false;  //运行宏时是否显示警告和消息

     XLApp.ScreenUpdating:

=false;    //屏幕更新功能,提高速度;

     XLApp.WorkBooks.Add(EXLfile);

     workbook:

=XLApp.workbooks[1];

     sheet:

=workbook.worksheets[1];

    //sheet:

=XLApp.WorkBooks[1].worksheets[1];

   //得到最大行数  maxRow

     XLApp.ActiveCell.SpecialCells(xlLastCell).Select;

     maxRow:

=XLApp.ActiveCell.Row;  //当前行数

    //最大行数

    //写数据到access库

     withDm1.aq_tempdo

     begin

       Close;

       SQL.Clear;

       SQL.Add('select*frompeo');

       open;

       foriRow:

=1toMaxRowdo//  循环次数为excel最大行数字-1,因为excel的第1行为IDname表头。

       begin

         Edit;

         Append;

         fieldByName('P_No').asString:

=sheet.cells[iRow,1];

         fieldByName('P_Name').asString:

=sheet.cells[iRow,2];//导入

         post;

       end;

     end;

     finally

     ifnotVarIsEmpty(XLApp)then

     begin  //释放对象

       XLApp.displayAlerts:

=false;

       XLApp.ScreenUpdating:

=true; //结束后,ScreenUpdating设回到True

       XLApp.quit;

     end;

    screen.Cursor:

=crDefault;

   end;

 end;

end;

 

现在sql里有book的表,里面有 

id             书名               价格 

id           bookname         price 

1             社会与科学            18 

2             delphi入门           25 

3             百科                  30 

在delphi里现在希望先把数据从excel导入到dbgrid中,然后点“批量插入”时,把刚才所有存到导入的dbgrid的数据插入到sql中,问一下大家怎么才能做到,有二个关键代码 

1.button1:

“从excel导入到dbgrid中”的关键代码 

2.button2:

"批量插入dbgrid数据到数据库中"的关键代码 

如果利用dbgrid其实就是利用数据集来操作

从excel读数据,然后利用

adoquery.append;

adoquery.fieldbyname('').value :

= 读的值

....

...

然后,对dbgrid进行编辑.

最后adoquery.post;就达到了批量提交了.

但这里要用事务来控制.

读Excel代码:

利用一个结构体,供你参考

var

  RangeMatrix:

 Variant;

  OpenDialog1:

 TOpenDialog;

  iRE:

 integer;

  IN_TYPE,vStockName:

 String;

  sStockName,sCompany:

 String;

  i:

 Integer;

  MsExcel, MsExcelWorkBook, MsExcelWorkSheet:

 Variant;

  ASN2_NEW:

 PASN2_NEW;

begin

  OpenDialog1:

=TOpenDialog.Create(nil);

  try

    OpenDialog1.FileName:

='*.csv;*.xls';

    if not OpenDialog1.Execute then

    begin

      Result :

= false;

      exit;

    end;

    MsExcel :

= CreateOleObject('Excel.Application');

    MsExcelWorkBook :

= msExcel.Workbooks.Open(OpenDialog1.FileName);

    MsExcelWorkSheet :

= msExcel.Worksheets.Item[1];

  except

    Result :

= false;

  end;

  //开始从EXCEL文件读取相关的信息

  try

    Application.ProcessMessages;

     for i :

= 1 to MsExcelWorkSheet.Rows.Count do

    begin

      New(FASN2);

      FASN2.In_Stock_No :

= trim(MsExcelWorkSheet.Range['B1'].Value);

      FASN2.MAIN_FLG :

= trim(MsExcelWorkSheet.Range['A' + IntToStr(i)].Value);

      FAsn2List.Add(FASN2);

      //在这里可以调用adoquery.append代码

    end;

    Result :

= true;

  finally

    MsExcel.WorkBooks.Close;

  end;

  MsExcel.Quit;

  OpenDialog1.Free;

end;

为了更清淅的表达我的意思,上传一张图

在delphi里现在希望先把数据从excel导入到dbgrid中,然后点“批量插入”时,把刚才所有存到导入的dbgrid的数据插入到sql中,问一下大家怎么才能做到,有二个关键代码  

1.button1:

“从excel导入到dbgrid中”的关键代码  

2.button2:

"批量插入dbgrid数据到数据库中"的关键代码  

//excel 读到 dbgrid

  

var

  str:

string;

begin

  str:

='select * from opendatasource(''microsoft.jet.oledb.4.0'',''data source="文件路径";user id=admin;password=;extened properties=excel 5.0'')...[sheet1$]';

  adoquery.close;

  adoquery.sql.clear;

  adoquery.sql.add(str);

  adoquery.active:

=true;

  adoquery.open;

end;

  

//dbgrid 导入数据表

  

var

  str:

string;

begin

  str:

='select *  into t from opendatasource(''microsoft.jet.oledb.4.0'',''data source="文件路径";user id=admin;password=;extened properties=excel 5.0'')...[sheet1$]';

  with adoquery do

    begin

      close;

      sql.clear;

      sql.add(str);

      execsql;

      if rowsaffected>0 then

        showmessage('插入成功')

      else

        showmessage(插入失败);

    end;

     

end;

致:

sz9214e

  感谢你的回帖,其实这二个帖有一部分是重复的,就是把dbgrid数据批量插入到sql中,不同是的

这个帖重点:

  把数据从excel导到dbgrid中,再把dbgrid数据批量插入到sql中

下一个帖的重点是:

  先在DBGrid1中存放N条记录,但不要即时存入数据库中,全部录入完成时再把dbgrid数据批量插入到sql中 

  上周因受了点伤没有上班,今天才开始上班,再次感谢你的回帖,能否把源程序发给我,这样我觉得快些,谢谢!

    我的email是:

ansameye@

解决问题的代码:

procedure TForm1.btnClick(Sender:

 TObject);

begin

  OpenDialog1.Title :

= '请选择正确的excel文件';

  OpenDialog1.Filter :

= 'Excel(*.xls)|*.xls';

  if OpenDialog1.Execute then

    edit1.Text :

= OpenDialog1.FileName;

end;

procedure TForm1.btninClick(Sender:

 TObject);

const

    

    BeginRow = 2; BeginCol = 1;

var

    Excel:

 OleVariant;

    iRow,iCol :

 integer;

    xlsFilename:

 string;

begin

if (trim(edit1.Text) = '') then

  begin

    MessageBox(GetActiveWindow(), 请选择正确的excel路径', MB_OK +

      MB_ICONWARNING);

    exit;

  end;

  xlsFilename :

= trim(edit1.Text);

    try

        Excel :

= CreateOLEObject('Excel.Application');

    except

        Application.MessageBox('excel没有安装', '提示信息', MB_OK+MB_ICONASTERISK+MB_DEFBUTTON1+MB_APPLMODAL);

        Exit;

    end;

    Excel.Visible :

= false;

    Excel.WorkBooks.Open(xlsFilename);

    try

        iRow :

= BeginRow;

        iCol :

= BeginCol;

        

        while trim(Excel.WorkSheets[1].Cells[iRow,iCol].value) <> '' do begin

            with ADOQuery1 do begin

                Append;

                Fields[0].AsString :

= trim(Excel.WorkSheets[1].Cells[iRow,iCol].value);

                Fields[1].AsString :

= trim(Excel.WorkSheets[1].Cells[iRow,iCol+1].value);

                Fields[2].Asstring :

= trim(Excel.WorkSheets[1].Cells[iRow,iCol+2].value);

                iRow :

= iRow + 1;

            end;

        

   end;

        Excel.Quit;

        ADOQuery1.UpdateStatus ;

    except

        Application.MessageBox('导入数据出错', '提示信息', MB_OK+MB_ICONASTERISK+MB_DEFBUTTON1+MB_APPLMODAL);

        Excel.Quit;

    end;

   MessageBox(GetActiveWindow(), '数据导入成功', '提示信息', MB_OK +

        MB_ICONWARNING);

end;

如何在DELPHI中将EXCEL中的数据导入到SQL数据库

var

 s1:

string;

begin

 screen.Cursor:

=crSQLWait;

 s1:

='insertintotable_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车号,dbo.uf_GetFullNameCode(车型名称),dbo.uf_GetFullNameCode(所属单位),dbo.uf_GetFullNameCode(厂牌型号),核定座位,售票座位,驾驶室前排座位,dbo.uf_GetFullNameCode(燃料名称),购置证号,本外单位,启用日期,dbo.uf_ConvertNullDate(终止时间)'+

     'FROMOpenDataSource(''Microsoft.Jet.OLEDB.4.0'',''DataSource="'+trim(LabeledEdit1.text)+'";ExtendedProperties=Excel8.0;PersistSecurityInfo=False'')...[Sheet1$]'+

     'where车号notin(selectbs_nofromtable_bus)';

 try

   DataModule1.ADOConnection1.Execute(s1);

 finally

   screen.Cursor:

=crArrow;

 end;

end;

 

 EXCEL是可以当成一种数据源来处理的。

 Str:

='Provider=Microsoft.Jet.OLEDB.4.0;DataSource='+文件路径+

   ';ExtendedProperties=Excel8.0;PersistSecurityInfo=False';

然后每列相当于一字段 

 

熟悉SQLSERVER2000的数据库管理员都知道,其DTS可以进行数据的导入导出,其实,我们也可以使用Transact-SQL语句进行导入导出操作。

在Transact-SQL语句中,我们主要使用OpenDataSource函数、OPENROWSET函数,关于函数的详细说明,请参考SQL联机帮助。

利用下述方法,可以十分容易地实现SQLSERVER、ACCESS、EXCEL数据转换,详细说明如下:

一、SQLSERVER和ACCESS的数据导入导出

常规的数据导入导出:

使用DTS向导迁移你的Access数据到SQLServer,你可以使用这些步骤:

  ○1在SQLSERVER企业管理器中的Tools(工具)菜单上,选择DataTransformation

  ○2Services(数据转换服务),然后选择czdImportData(导入数据)。

  ○3在ChooseaDataSource(选择数据源)对话框中选择MicrosoftAccessastheSource,然后键入你的.mdb数据库(.mdb文件扩展名)的文件名或通过浏览寻找该文件。

  ○4在ChooseaDestination(选择目标)对话框中,选择MicrosoftOLE DBProviderforSQL Server,选择数据库服务器,然后单击必要的验证方式。

  ○5在SpecifyTableCopy(指定表格复制)或Query(查询)对话框中,单击Copytables(复制表格)。

○6在SelectSourceTables(选择源表格)对话框中,单击SelectAll(全部选定)。

下一步,完成。

Transact-SQL语句进行导入导出:

1.在SQLSERVER里查询access数据:

SELECT*

FROMOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/DB.mdb";UserID=Admin;Password=')...表名

2.将access导入SQLserver

在SQLSERVER里运行:

SELECT*

INTOnewtable

FROMOPENDATASOURCE('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/DB.mdb";UserID=Admin;Password=')...表名

3.将SQLSERVER表里的数据插入到Access表中

在SQLSERVER里运行:

insertintoOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/DB.mdb";UserID=Admin;Password=')...表名

(列名1,列名2)

select列名1,列名2fromsql表

实例:

insertintoOPENROWSET('Microsoft.Jet.OLEDB.4.0',

'C:

/db.mdb';'admin';'',Test)

selectid,namefromTest

INSERTINTOOPENROWSET('Microsoft.Jet.OLEDB.4.0','c:

/trade.mdb';'admin';'',表名)

SELECT*

FROMsqltablename

二、SQLSERVER和EXCEL的数据导入导出

1、在SQLSERVER里查询Excel数据:

SELECT*

FROMOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/book1.xls";UserID=Admin;Password=;Extendedproperties=Excel5.0')...[Sheet1$]

下面是个查询的示例,它通过用于Jet的OLEDB提供程序查询Excel电子表格。

SELECT*

FROMOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/Finance/account.xls";UserID=Admin;Password=;Extendedproperties=Excel5.0')...xactions

2、将Excel的数据导入SQLserver:

SELECT*intonewtable

FROMOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/book1.xls";UserID=Admin;Password=;Extendedproperties=Excel5.0')...[Sheet1$]

实例:

SELECT*intonewtable

FROMOpenDataSource('Microsoft.Jet.OLEDB.4.0',

'DataSource="c:

/Finance/account.xls";UserID=Admin;Password=;Extendedproperties=Excel5.0')...xactions

3、将SQLSERVER中查询到的数据导成一个Excel文件

T-SQL代码:

EXECmaster..xp_cmdshell'bcp库名.dbo.表名outc:

/Temp.xls-c-q-S"servername"-U"sa"-P""'

参数:

S是SQL服务器名;U是用户;P是密码

说明:

还可以导出文本文件等多种格式

实例:

EXECmaster..xp_cmdshell'bcpsaletesttmp.dbo.CusAccountoutc:

/temp1.xls-c-q-S"pmserver"-U"sa"-P"sa"'

EXECmaster..xp_cmdshell'bcp"SELECTau_fname,au_lnameFROMpubs..authorsORDERBYau_lname"queryoutC:

/authors.xls-c-Sservername-Usa-Ppassword'

在VB6中应用ADO导出EXCEL文件代码:

DimcnAsNewADODB.Connection

cn.open"Driver={SQLServer};Ser

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 经济市场

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1