zoukankan      html  css  js  c++  java
  • [转载]在SQL Server数据库之间进行数据导入导出,OPENDATASOURCE Virus

    需要在c盘下先建立一个data.txt文件,然后在文件的第一行写上你要导出的列,不如说要导出id和name这两列,就在第一行写上

    id,name

    然后保存,使用下列SQL就可以了,
    你如果要保持原有的Identity列。在插入之前先运行一下set  insert_identity  tableName on
    然后插入数据。这样就可以保留原来的值。运行完后再运行 set  insert_identity  tableName off
    这样你就可以了

    use
     DevTest
    go

    exec sp_configure 'show advanced options',1
    reconfigure
    exec sp_configure 'Ad Hoc Distributed Queries',1
    reconfigure
    go
    INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')[data#txt] SELECT * FROM test
    go
    exec sp_configure 'Ad Hoc Distributed Queries',0
    reconfigure
    exec sp_configure 'show advanced options',0
    reconfigure
    go 

    完整的sql代码如下

    use DevTest
    go
    -----导出数据
    exec sp_configure 'show advanced options',1
    reconfigure
    exec sp_configure 'Ad Hoc Distributed Queries',1
    reconfigure
    go
    INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')[data#txt] SELECT * FROM test
    go
    exec sp_configure 'Ad Hoc Distributed Queries',0
    reconfigure
    exec sp_configure 'show advanced options',0
    reconfigure
    go 
    delete from test
    go
    ----导入数据
    exec sp_configure 'show advanced options',1
    reconfigure
    exec sp_configure 'Ad Hoc Distributed Queries',1
    reconfigure
    go
    set identity_insert DevTest.dbo.test on
    insert into DevTest.dbo.test( id,[name]select * from
    OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')[data#txt] 
    set identity_insert DevTest.dbo.test off
    exec sp_configure 'Ad Hoc Distributed Queries',0
    reconfigure
    exec sp_configure 'show advanced options',0
    reconfigure
    go


    SQL Server SQL语句导入导出大全
    ,bcp
    http://www.pconline.com.cn/pcedu/empolder/db/sql/0502/551039.html

    bcp
    http://liss.javaeye.com/blog/185240

    http://zhidao.baidu.com/question/54612476.html
    bcp
    http://www.cnblogs.com/flyingbird/archive/2006/10/30/544452.html

    转载地址:http://tech.it168.com/db/s/2006-08-16/200608160913336.shtml

     【IT168 技术文档】本文讨论了如何通过Transact-SQL以及系统函数OPENDATASOURCE和OPENROWSET在同构和异构数据库之间进行数据的导入导出,并给出了详细的例子以供参考。

      1. 在SQL Server数据库之间进行数据导入导出

      (1).使用SELECT INTO导出数据  

      在SQL Server中使用最广泛的就是通过SELECT INTO语句导出数据,SELECT INTO语句同时具备两个功能:根据SELECT后跟的字段以及INTO后面跟的表名建立空表(如果SELECT后是*, 空表的结构和FROM所指的表的结构相同);将SELECT查出的数据插入到这个空表中。在使用SELECT INTO语句时,INTO后跟的表必须在数据库不存在,否则出错,下面是一个使用SELECT INTO的例子。

      假设有一个表table1,字段为f1(int)、f2(varchar(50))。

    SELECT * INTO table2 FROM table1

      这条SQL语的在建立table2表后,将table1的数据全部插入到table1中的,还可以将*改为f1或f2以便向适当的字段中插入数据。

      SELECT INTO不仅可以在同一个数据中建立表,也可以在不同的SQL Server数据库中建立表。

    USE db1
    SELECT * INTO db2.dbo.table2 FROM table1

      以上语句在数据库db2中建立了一个所有者是dbo的表table2,在向db2建表时当前登录的用户必须有在db2建表的权限才能建立 table2。    使用SELECT INTO要注意的一点是SELECT INTO不可以和COMPUTE一起使用,因为COMPUTE返回的是一组记录集,这将会引起二意性(即不知道根据哪个表建立空表)。

      (2).使用INSERT INTO 和 UPDATE插入和更新数据

      SELECT INTO只能将数据复制到一个空表中,而INSERT INTO可以将一个表或视图中的数据插入到另外一个表中。

    INSERT INTO table1 SELECT * FROM table2

    INSERT INTO db2.dbo.table1 SELECT * FROM table2

      但以上的INSERT INTO语句可能会产生一个主键冲突错误(如果table1中的某个字段是主键,恰巧table2中的这个字段有的值和table1的这个字段的值相同)。因此,上面的语句可以修改为

    INSERT INTO table1 -- 假设字段f1为主键
    SELECT * FROM table2 WHERE
    NOT EXISTS(SELECT table1.f1 FROM table1 WHERE table1.f1=table2.f1 )

      以上语句的功能是将table2中f1在table1中不存在的记录插入到table1中。

      要想更新table1可以使用UPDATE语句

    UPDATE table1 SET table1.f1=table2.f1, table1.f2=table2.f2 FROM table2
    WHERE table1.f1=table2.f1

      将以上两条INSERT INTO和UPDATE语句组合起来在一起运行,就可以实现记录在table1中不存在时插入,存在时更新的功能,但要注意要将UPDATE放在 INSERT INTO前面,否则UPDATE更新的记录数将是table1和table2记录数的总和。


     2. 使用OPENDATASOURCE和OPENROWSET在不同类型的数据库之间导入导出数据

      在异构的数据库之间进行数据传输,可以使用SQL Server提供的两个系统函数OPENDATASOURCE和OPENROWSET。

      OPENDATASOURCE可以打开任何支持OLE DB的数据库,并且可以将OPENDATASOURCE做为SELECT、UPDATE、INSERT和DELETE后所跟的表名。如

    SELECT * FROM
    OPENDATASOURCE('SQLOLEDB', 'Data Source=192.168.18.252;User ID=sa;Password=test').pubs.dbo.authors

      这条语句的功能是查询192.168.18.252这台机器中SQL Server数据库pubs中的authors表。从这条语句可以看出,OPENDATASOURCE有两个参数,第一个参数是 provider_name,表示用于访问数据源的 OLE DB 提供程序的 PROGID 的名称。provider_name 的数据类型为 char,没有默认值。第二个参数是连接字符串,根据OLE DB Provider不同而不同(如果不清楚自己所使用的OLE DB Provider的连接字符串,可以使用delphi、visual studio等开发工具中的ADO控件自动生成相应的连接字符串)。

      OPENROWSET函数和OPENDATASOURCE函数类似,只是它可以在打开数据库的同时对数据库中的表进行查询,如以下语句

    OPENROWSET('MSDASQL.1', 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\db; SourceType=DBF', 'SELECT * FROM [b.dbf]')

      最后一个参数查询foxpro表b.dbf,读者可以通过where条件对b.dbf进行过滤。如果将INSERT INTO、SELECT INTO和OPENDATASOURCE或OPENROWSET一起使用,就可以使SQL Server数据库和其它类型的数据库之间进行数据导入导出。下面介绍如何使用这两个函数在SQL Server数据库和其它类型的数据库之间进行数据导入导出。

      (1).SQL Server数据库和SQL Server数据库之间的数据导入导出。

      导入数据

    SELECT * INTO authors1
    FROM OPENDATASOURCE(
    'SQLOLEDB',
    'Data Source=192.168.18.252;User ID=sa;Password=abc'
    ).pubs.dbo.authors

      导出数据

    INSERT INTO OPENDATASOURCE(
    'SQLOLEDB',
    'Data Source=192.168.18.252;User ID=sa;Password=abc'
    ).test.dbo.authors
    select * from pubs.dbo.authors

      在这条语句中OPENDATASOURCE(...)可以理解为SQL Server的一个服务,.pubs.dbo.authors是这个服务管理的一个数据库的一个表authors。使用INSERT INTO时OPENDATASOURCE(...)后跟的表必须存在。

      也可以将以上的OPENDATASOURCE换成OPENROWSET

    INSERT INTO OPENROWSET('SQLOLEDB','192.168.18.252';'sa';'abc', 'select * from test.dbo.kk')
    SELECT * FROM pubs.dbo.authors

      使用OPENROWSET要注意一点,'192.168.18.252';'sa';'abc'中间是";",而不是","。OPENDATASOURCE和OPENROWSET都不接受参数变量。

      (2). SQL Server数据库和Access数据库之间的数据导入导出。

      导入数据

    SELECT * INTO access
    FROM OPENDATASOURCE(
    'Microsoft.Jet.OLEDB.4.0',
    'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False')...table1

      或者使用OPENROWSET

    SELECT * FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\data.mdb';'admin';'','SELECT * FROM table1')

      导出数据

    INSERT INTO OPENDATASOURCE(
    'Microsoft.Jet.OLEDB.4.0',
    'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False')...table1
    SELECT * FROM access

      打开access数据库的OLE DB Provider叫Microsoft.Jet.OLEDB.4.0,需要注意的是操作非SQL Server数据库在OPENDATASOURCE(...)后面引用数据库中的表时使用"...”,而不是“.”。 

      (3). SQL Server数据库和文本文件之间的数据导入导出。

      导入数据

    SELECT * INTO text1 FROM
    OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')...[data#txt]

      导出数据

    INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')...[data#txt] SELECT * FROM text1

      或者使用OPENROWSET 

    INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\', [data#txt]) SELECT * FROM text1

      如果要插入部分字段,可使用

    INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\', 'SELECT aa FROM [data#txt]') SELECT aa FROM text1

       这条SQL语句的功能是将c盘根目录的data.txt文件导入到text1表中,在这里文件名中的“.”要使用“#”代替。在向文本导出时,不仅文本文件要存在,而且第一行必须和要导出表的字段一至。

    (4). SQL Server数据库和dbase数据库之间的数据导入导出。

      导入数据  

    SELECT * INTO dbase FROM
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0' , 'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','SELECT * FROM [b.dbf]')

      导出数据

    INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0' , 'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','SELECT * FROM [b.dbf]')
    SELECT * FROM dbase

      OPENROWSET(...)中的b.dbf使用[...]括起来,是为了当dbf文件名有空格等字符时不会出错,如果没有这些特殊字符,可以将[...]去掉

      (5). SQL Server数据库和foxpro数据库之间的数据导入导出。

      导入数据

    SELECT * INTO foxpro FROM OPENROWSET('MSDASQL.1', 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\; SourceType=DBF', 'SELECT * FROM [a.dbf]')

      导出数据

    INSERT INTO OPENROWSET('MSDASQL.1' , 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\db; SourceType=DBF','SELECT * FROM a.dbf') SELECT * FROM foxpro

      在此处a.dbf不能使用[...]括起来,否则出错(这是由driver决定的)。

      (6). SQL Server数据库和excel文件之间的数据导入导出

      导入数据

    SELECT * INTO excel FROM OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0',
    'Excel 5.0;DATABASE=c:\book1.xls' )...[Sheet1$]

      导出数据

    INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0',
    'Excel 5.0;DATABASE=c:\book1.xls' )...[Sheet1$] SELECT * FROM excel

      在book1.xls的Sheet1中必须有和excel表相对应的字段,否则会出错。

      以上讨论了几种常用的数据库和SQL Server数据库之间如何使用Transact-SQL进行数据导入导出。在SQL Server中还提供了将其它类型的数据库注册到SQL Server中的功能,这样就可以和使用SQL Server数据库表一样使用这些被注册数据库中的表了。

    EXEC sp_addlinkedserver
    'access',
    'OLE DB Provider for Jet',
    'Microsoft.Jet.OLEDB.4.0',
    'c:\data.mdb'

      以上SQL使用存储过程sp_addlinkedserver注册了一个access数据库,我们可以在SQL Server中使用如下语句查询在data.mdb中的table1。

    SELECT * FROM access...table1

      这样就可很方便地查询access数据库中的表了,如果要导入table1,可以使用SELECT * INTO table2 FROM access...table1。如果想删除注册的数据库连接,使用如下语句。

    EXEC sp_dropserver 'access'

      使用Transact-SQL不仅可以向SQL Server数据库导入导出数据,而且还可以使任意两种类型数据库之间互相导入导出数据。以access和excel为例进行说明。    

    INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0',
    'Excel 5.0;DATABASE=c:\book1.xls' )...[Sheet1$] SELECT * FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\data.mdb';'admin';'','SELECT * FROM table1')

      以上SQL语句将access数据库的table1表的数据插入到excel文件book1.xls中的Sheet1表单中。

      使用Transact-SQL进行数据的导入导出,可以很方便地将这些Transact-SQL语句放到客户端程序中(如delphi、c#等),从而可以很容易地编写自已的数据库导入导出工具。


    【Blog】http://virusswb.cnblogs.com/

    【MSN】jorden008@hotmail.com

    【说明】转载请标明出处,谢谢

    反馈文章质量,你可以通过快速通道评论:

  • 相关阅读:
    A1052. Linked List Sorting (25)
    A1032. Sharing (25)
    A1022. Digital Library (30)
    A1071. Speech Patterns (25)
    A1054. The Dominant Color (20)
    A1060. Are They Equal (25)
    A1063. Set Similarity (25)
    电子码表
    矩阵键盘
    对象追踪、临时对象追踪、绝对坐标与相对坐标
  • 原文地址:https://www.cnblogs.com/virusswb/p/1276827.html
Copyright © 2011-2022 走看看