如何把 *.mdb,*.dbf 导入到sql server 2000 中,!源码100分!

解决方案 »

  1.   

    有2中办法用程序写的话,就用2个Database一个连Access,一个连SQL 2000
    对每个表做循环导入。
    还有是在SQL 2000的企业管理器中可以用数据导入啊!
    如果是同一个库,还可以用Insert into TableName values(select * from TableName) 字段要对应
      

  2.   

    USE pubsGOSELECT c.*, o.*FROM Northwind.dbo.Customers AS c INNER JOIN 
        OPENROWSET('Microsoft.Jet.OLEDB.4.0', 
        'c:\MSOffice\Access\Samples\northwind.mdb';'admin';'mypwd', Orders) 
        AS o
        ON c.CustomerID = o.CustomerID GO
      

  3.   

    2:异质数据库连接可以用SQL中的OPENROWSET或OPENQUERY
    方法3:
    1.打开SQL server(本人用SQL SERVER2000)的企业管理器
    2.新建一个数据库,库名自定.再选中刚建立好的数据库
    3.选择:工具-数据转换服务-导出数据
    4.选择数据源为:miscrosft access,  再指定"文件名","用户"和"密码"
    5.下一步:("目的" 不用改动)
    6.下一步-全选-下一步-完成
    7.刷新 数据库即可.
      

  4.   

    同意 killer2008(现代汉语词典) 
        用OPENROWSET或OPENQUERY应该还是能保证速度的。
      

  5.   

    转:用Delphi实现不同数据库系统之间的数据转移在计算机应用系统的软件升级改造过程中,我们经常遇到这样一个问题:老系统的数据库平台与新系统不同。例如,老系统的数据库平台是Foxpro,而新系统的平台是SQL Server。而且,我们需要把旧的数据库应用系统中的一些数据转移到新系统来。但是因为新老系统在定义数据类型、数据格式等方面的差异,就很难用人工录入的方法来实现。因此,需要有一个能实现这种功能的程序。
    本文利用Borland Delphi实现了这个转移过程。
    基本思想是:在一个Form中,分别用两个TDatabase控件连接新老数据库。并采用TTable、TDbGrid作为数据转移的中心,根据DbGrid中的数据生成标准的SQL插入语句。这样,就实现了从一个数据库系统到另一个数据库系统的数据转移。在这里,采用TTable、TDbGrid作为数据转移的中心是一个技巧,因为:TTable的Fields属性能指示出某字段的字段名称、数据类型等,这为数据转移过程中的Insert语句的生成及数据类型转换提供了依据。
    下面的例子展示了从Foxpro到SQL Server的数据转移方法。至于其他系统间的数据转移,只要根据目标系统的数据定义要求,修改相应的Insert语句。
    程序代码如下:
    unit ConvertDBF;
    interface
    uses
     Windows, Messages, SysUtils, Classes,
     Graphics, Controls, Forms, Dialogs,
     StdCtrls, DBTables, Db, Grids, DBGrids;
    type
     TfrmConvertDB = class(TForm)
      btnOK: TButton;
      Label1: TLabel;
      db1: TDatabase;  {用于连接老数据库系统}
      db2: TDatabase;  {用于连接新数据库系统}
      dbg: TDBGrid; 
      tblSource: TTable; {dbg的Datasource}
    qryInsert: TQuery;
       {用于存放生成的SQL Insert语句}
      srcSource: TDataSource;
      tblDest: TTable; {DBGrid1的Datasource}
      DBGrid1: TDBGrid;
      srcDest: TDataSource;
      edFromtbl: TEdit;
      Label2: TLabel;
      Label3: TLabel;
      edToTbl: TEdit;
      procedure btnOKClick(Sender: TObject);
     private
      { Private declarations }
     public
      { Public declarations }
     end;
    var
     frmConvertDB: TfrmConvertDB;
    implementation
    {$R *.DFM}
    procedure TfrmConvertDB.btnOKClick
     (Sender: TObject);
    var iField :integer;
    begin
     if ((edTotbl.text<>'') and 
     (edFromtbl.text<>''))then begin
     tblSource.TableName:=edFromtbl.text; 
              {指定TableName}
     tblDest.TableName:=edTotbl.text;
     with tblSource do begin
       Open; {打开老系统的表}
       while EOF=FALSE do begin
           {逐条记录处理}
        qryInsert.SQL.Clear;
    qryInsert.sql.Add
    ('Insert into '+edTotbl.text + '(');
        for iField:=0 to dbg.FieldCount-1 do begin
          qryInsert.sql.add
         (dbg.Fields[iField].DisplayLabel);
          if iField<>dbg.FieldCount-1 then
           qryInsert.sql.add(',');
        end;
        qryInsert.sql.add(') values(');
    for iField:=0 to dbg.FieldCount-1 do begin
        {进行数据类型转换}
          if dbg.fields[iField].DataType=ftInteger then
           qryInsert.sql.add(inttostr
          (dbg.fields[iField].asInteger));
          if dbg.fields[iField].DataType=ftFloat then
           qryInsert.sql.add(floattostr
          (dbg.fields[iField].asFloat));
          if dbg.fields[iField].DataType=ftDate then
           qryInsert.sql.add(''''+datetostr
          (dbg.fields[iField].asDateTime)+'''');
          if dbg.fields[iField].DataType=ftString then begin
           if dbg.fields[iField].asString<>'' then
            qryInsert.sql.add(''''+dbg.fields
            [iField].asString+'''')
           else
            qryInsert.sql.add('NULL');
          end;
          if iField<>dbg.FieldCount-1
          then qryInsert.sql.add(',');
        end;
        qryInsert.sql.add(')');
    qryInsert.ExecSQL;
                  {把数据插入到新系统的表中}
        next;
       end;
     end;
     tblDest.Close;
     tblDest.Open;;
     ShowMessage(' 转换完毕!  ');
     end
     else
      ShowMessage
      ('请输入要插入数据的表的名称  ');
    end;
    end.
      

  6.   

    同意 killer2008(现代汉语词典)
      

  7.   

    在Delphi 中 利 用 Tbatch 组 件 完 成 数 据 批 处 理 
    作者: 军 械 工 程 学 院 五 系 研 究 生 队 王 俊  评价:  上站日期:  
    内容说明:  
    来源:  --------------------------------------------------------------------------------军 械 工 程 学 院 五 系 研 究 生 队 王 俊 
    ---- 在 数 据 库 应 用 系 统 中, 常 常 要 对 数 据 进 行 成 批 的 如 追 加、 删 除、 更 改 等
    操 作, 这 种 批 量 操 作 在 专 门 的 数 据 库 开 发 工 具 如VFP 中 用APPEND 、COPY 命 令
    带 上 相 应 的 命 令 子 句 就 能 轻 易 完 成。 但 在 其 它 开 发 工 具 中 并 没 有 类 似 的
    命 令, 而 是 提 供 能 完 成 类 似 功 能 的 控 件 或 对 象, 如 在PowerBuilder 中 就 是 利 用
    Pipe Line( 数 据 管 道) 来 完 成 两 个 或 同 构 或 不 同 构 的 表 之 间 的 数 据 批 处 理。 
    本 文 要 介 绍 的 是Delphi 中 用 来 完 成 数 据 批 处 理 任 务 的 组 件TBatchMove。TBatchMove 组
    件 能 够: 
    将 一 个 数 据 集 中 的 数 据 追 加 到 一 个 表 中。. 
    从 一 个 表 中 删 除 满 足 条 件 的 记 录。 按 旧 表 结 构 生 成 一 个 新 表, 若 欲 生 成 的 新 表 已 存 在, 则 覆 盖。 
     ---- 具 体 的 操 作 要 通 过 设 置TBatchMove 的Mode 属 性 后 再 调 用Execute 方 法 来 完 成。 为
    举 例 说 明 问 题, 我 们 在 别 名 数 据 库DBDEMOS 中 先 创 建 两 个dBase 格 式 的 表Test1.dbf
    和Test2.dbf。 二 者 的 结 构 如 下 表:    Test1.dbf Test2.dbf
        Name C 10 Name C 10
        Code C 3 Code C 3
     ---- 其 中 表Test2.dbf 在 字 段code 上 建 立 有 唯 一 索 引。 同 时 假 设 表 单 中 已 有 两 个
    TABLE 控 件Tsource 和Tdest 和 一 个TbatchMove 组 件batchmove1。Tsource 和Tdest 的DatabaseName 属 性 均
    设 为DBDEMOS。batchmove1 的source 属 性 设 为Tsource,destination 属 性 设 为Tdest。
    ---- 在 使 用TbatchMove 组 件 时, 必 须 牢 记: 所 有 的 操 作 都 是 以 源 表 为 标 准 针 对 目
    的 表 进 行 的, 下 面 就 分 别 举 例 说 明TbatchMove 的 各 种 操 作 模 式: batAppend 追 加 模 式 将 源 表 中 的 数 据 追 加 到 目 的 表 中, 目 的 表 必 须 事 先 存
    在。 这 是 缺 省 模 式。 
    batchmove1.source=Tsource; 
    batchmove1.destination=Tdest2 ; 
    batchmove1.Mode:=batCopy; 
    batchmove1.Execute; batUpdate 更 新 模 式 用 源 表 中 匹 配 目 的 表 的 记 录 替 换 目 的 表 中 的 相 应 记
    录。 目 的 表 必 须 事 先 存 在 且 有 一 已 定 义 的 索 引 用 来 匹 配 源 表 中 的 记
    录。 
    Tdest.IndexFieldNames:='code'; 
    batchmove1.source=Tsource; 
    batchmove1.destination=Tdest ; 
    batchmove1.Mode:=batUpdate; 
    batchmove1.Execute; batAppendUpdate 追 加 更 新 模 式 如 果 源 表 中 有 与 目 的 表 匹 配 的 记 录, 则 替 换
    目 的 表 记 录, 否 则, 直 接 追 加 到 目 的 表 中。 目 的 表 必 须 事 先 存 在 且 有 一
    已 定 义 的 索 引 用 来 匹 配 源 表 中 的 记 录。 
    Tdest.IndexFieldNames:='code'; 
    batchmove1.source=Tsource; 
    batchmove1.destination=Tdest ; 
    batchmove1.Mode:=batAppendUpdate; 
    batchmove1.Execute; batCopy 拷 贝 模 式 按 源 表 结 构 生 成 新 表, 源 表 中 的 数 据 同 时 拷 贝 到 目 的
    新 表 中。 如 果 要 生 成 的 新 表 已 存 在, 则 覆 盖。 
    // 按Test1.dbf 生 成 新 表xxx.dbf 
    // 如 果 不 指 定 扩 展 名dbf, 生 成 的 新 表 将 是Paradox 格 式 的xxx.db。 
    Tdest.TableName:='xxx.dbf'; 
    batchmove1.source=Tsource; 
    batchmove1.destination=Tdest ; 
    batchmove1.Mode:=batCopy; 
    batchmove1.Execute; batDelete 删 除 模 式 删 除 目 的 表 中 与 源 表 匹 配 的 记 录。 目 的 表 必 须 事 先 存
    在 且 有 一 已 定 义 的 索 引 用 来 匹 配 源 表 中 的 记 录。 
    Tdest.IndexFieldNames:='code'; 
    batchmove1.source=Tsource; 
    batchmove1.destination=Tdest ; 
    batchmove1.Mode:=batDelete; 
    batchmove1.Execute; 
     ---- TBatchMove 还 有 一 个 重 要 属 性ChangedTableName, 在 实 际 运 用 中, 通 过 指 定
    ChangedTableName 属 性 可 以 创 建 一 个Paradox 表, 该 表 用 来 保 存 目 的 表 中 被 更 改 数 据
    的 原 始 备 份, 有 了 这 个 备 份 表 就 可 以 确 保 恢 复 目 的 表 中 的 数 据。 ---- 顺 便 提 一 句, 如 果 要 删 除 某 一 个 表 中 的 全 部 记 录, 可 以 采 用Table 组 件 的
    EmptyTable 方 法, 例 如Tdest.EmptyTable 将 清 空Tdest 所 指 定 的 表test2.dbf。 ---- 本 文 中 是 以 同 构 的dbf 表 进 行 的 示 例, 在 实 际 运 用 中, 源 表 和 目 的 表 可 能
    同 购, 也 可 能 异 构, 异 构 时,Delphi 的BDE 会 自 动 进 行 类 型 和 长 度 上 的 转 换, 具
    体 类 型 间 的 关 系 可 以 有 关BDE 的 帮 助。 本 文 中 各 种 操 作 模 式 的 实 际 结 果 均
    可 以 从Delphi 的Database Desktop 中 查 看 到。