就是说我想实现,希望备份某个数据库中的哪几个指定表就备份那几个表,如何实现呢
望高手指点!谢谢

解决方案 »

  1.   

    backup 命令是不支持的,不像oracle的exp命令你可以用导入导出,或者bcp
      

  2.   

    1、backup命令的语法结构:
    BACKUP DATABASE{database_name|@database_name_var}
     TO<backup_device>[,...n]
     [WITH
     [FORMAT]          //不仅可以重写备份,还可以拆分备份文件  
     [[,]{INIT|NOINT}  //指定是重写备份还是追加备份文件
     ]****由此可见,backup命令仅仅适用于备份数据库,而不能单单指定数据表。2、bcp工具:用于在实例和数据文件之间以用户指定的格式复制数据。
    ***************可将导出的TXT文件作为数据表的备份************************
    bcp命令格式如下:bcp {[[database_name.][owner].]{table_name | view_name} | "query"}
        {in | out | queryout | format} data_file
        [-m max_errors] [-f format_file] [-e err_file]
        [-F first_row] [-L last_row] [-b batch_size]
        [-n] [-c] [-w] [-N] [-V (60 | 65 | 70)] [-6]
        [-q] [-C code_page] [-t field_term] [-r row_term]
        [-i input_file] [-o output_file] [-a packet_size]
        [-S server_name[\instance_name]] [-U login_id] [-P password]
        [-T] [-v] [-R] [-k] [-E] [-h "hint [,...n]"]举个简单的例子:
    将保存在数据库AAA中的表bbb导出到bbbtxt.txt中:
    bcp "AAA.dbo.bbb" out "f:\bbbtxt.txt" -c -U登陆名 -P密码
      

  3.   

    我想在delphi中用代码实现
    能告诉我怎么做吗,谢谢
      

  4.   

    谢谢ronk(辉月灵鸣),那么只能用bcp了
    但是导出后如何导入呢,还用bcp吗
      

  5.   

    ADODataSetBackup.close;
    ADODataSetBackup.commandtext:='Select * from tablename';
    ADODataSetBackup.open;...
    //备份
    ADODataSetBackup.savetofile('备份文件名');//恢复
    ADODataSetRestore.loadfromfile('备份文件名');
    ADODataSetRestore.post;
      

  6.   

    导入的话将 out 改成 in 就可以了。
    举个简单的例子:
    将bbbtxt.txt中的数据导入数据库AAA中的bbb表:
    bcp "AAA.dbo.bbb" in "f:\bbbtxt.txt" -c -U登陆名 -P密码
      

  7.   

    我所写的是MSSQL数据库的BCP工具,运行-》cmd -》输命令,如果是在DELPHI中实现的话可以利用chenylin(陈SIR)的方法。
    我原本考虑是用ADOCOMMAND写SQL语句的,想不到还有更便捷的方法,真是受益非浅啊~~~~学习学习再学习!!!
      

  8.   

    谢谢了,真是让我受益匪浅,我马上就去试试
    不论是ronk(辉月灵鸣)还是chenylin(陈SIR)的方法,我都觉得很棒!
      

  9.   

    chenylin(陈SIR):
    恢复似乎不可用:
     ADODataSetRestore.close;
    ADODataSetRestore.commandtext:='Select * from tablename';
    ADODataSetRestore.open;ADODataSetRestore.loadfromfile('filename');
    ADODataSetRestore.post;
    是这样写吗
      

  10.   

    是否可以建立一个新的数据库,然后将要备份的表select into到新数据库中的表去,然后备份这个新数据库?
    恢复只要倒过来做即可
    但这样似乎很麻烦~
      

  11.   

    你的想法可以实现,但是这样性能的开销也许会比原来多哦~~~难不成你一个表建一个数据库?
    但这样也有优点:如果是导出到TXT文件的话,该数据表的数据安全性可以说就等于零了~~如果是新建数据库然后再备份,至少比导出到TXT文件保密性要好~
      

  12.   

    这个问题我暂时还没考虑清楚,先帮你顶上去吧~~~~帮不上什么忙,真不好意思~~~如果你知道或者有了什么好的办法和主意的话,留言或者E-MAIL告诉我一下啊~~~我也很想知道问题解决的方案
    我的E-MAIL:[email protected]
      

  13.   

    SQL里不就有类似的工具吗?再把它转成SQL代码。研究一下。代入DELPHI。具体我得有参考资料。。在网吧。。没法顶。呵。。
      

  14.   

    okok
    你忙去吧
    有资料会给你的,你的邮箱我知道
    谢谢了~
      

  15.   

    数据量不大的话直接用数据库备份好点。如果表真的很大,用chenylin(陈SIR)的方法也不行,至少效率太低了。直接用bcp好一点。
      

  16.   

    直接用BCP备份是可以的.但是涉及到安全性的问题~~~~~因为保存的格式是TXT的嘛~~~万一有不合适的人察看了TXT文件,那基本上什么资料都被一览无疑了.
    陈SIR的方法我尝试过了,但是实现不了~~郁闷啊
      

  17.   

    前两天去看了一家财务软件公司开的会,发现现在有些财务软件确实采用的是把数据表导出为TXT格式文件~~~比如一些日结销售啊什么的~~~感觉怪怪的~~~
      

  18.   

    SQL语句导入导出大全 
    作者:  评价:  上站日期: 2004-04-17  
    内容说明:  
    来源:  --------------------------------------------------------------------------------/*******  导出到excel
    EXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:\temp1.xls -c -q -S"GNETDATA/GNETDATA" -U"sa" -P""'/***********  导入Excel
    SELECT * 
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
      'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions/*动态文件名
    declare @fn varchar(20),@s varchar(1000)
    set @fn = 'c:\test.xls'
    set @s ='''Microsoft.Jet.OLEDB.4.0'',
    ''Data Source="'+@fn+'";User ID=Admin;Password=;Extended properties=Excel 5.0'''
    set @s = 'SELECT * FROM OpenDataSource ('+@s+')...sheet1$'
    exec(@s)
    */SELECT cast(cast(科目编号 as numeric(10,2)) as nvarchar(255))+' ' 转换后的别名
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
      'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions/********************** EXCEL导到远程SQL
    insert OPENDATASOURCE(
             'SQLOLEDB',
             'Data Source=远程ip;User ID=sa;Password=密码'
             ).库名.dbo.表名 (列名1,列名2)
    SELECT 列名1,列名2
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
      'Data Source="c:\test.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions
    /** 导入文本文件
    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'
    BULK INSERT 库名..表名
    FROM 'c:\test.txt'
    WITH (
        FIELDTERMINATOR = ';',
        ROWTERMINATOR = '\n'
    )
    --/* dBase IV文件
    select * from 
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'dBase IV;HDR=NO;IMEX=2;DATABASE=C:\','select * from [客户资料4.dbf]')
    --*/--/* dBase III文件
    select * from 
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','select * from [客户资料3.dbf]')
    --*/--/* FoxPro 数据库
    select * from openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\',
    'select * from [aa.DBF]')
    --*//**************导入DBF文件****************/
    select * from openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;
    SourceDB=e:\VFP98\data;
    SourceType=DBF',
    'select * from customer where country != "USA" order by country')
    go
    /***************** 导出到DBF ***************/
    如果要导出数据到已经生成结构(即现存的)FOXPRO表中,可以直接用下面的SQL语句insert into openrowset('MSDASQL',
    'Driver=Microsoft Visual FoxPro Driver;SourceType=DBF;SourceDB=c:\',
    'select * from [aa.DBF]')
    select * from 表说明:
    SourceDB=c:\  指定foxpro表所在的文件夹
    aa.DBF        指定foxpro表的文件名. 
    /*************导出到Access********************/
    insert into openrowset('Microsoft.Jet.OLEDB.4.0', 
       'x:\A.mdb';'admin';'',A表) select * from 数据库名..B表/*************导入Access********************/
    insert into B表 selet * from openrowset('Microsoft.Jet.OLEDB.4.0', 
       'x:\A.mdb';'admin';'',A表)文件名为参数
    declare @fname varchar(20)
    set @fname = 'd:\test.mdb'
    exec('SELECT a.* FROM opendatasource(''Microsoft.Jet.OLEDB.4.0'',
        '''+@fname+''';''admin'';'''', topics) as a ')SELECT * 
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
      'Data Source="f:\northwind.mdb";Jet OLEDB:Database Password=123;User ID=Admin;Password=;')...产品*********************  导入 xml 文件DECLARE @idoc int
    DECLARE @doc varchar(1000)
    --sample XML document.BR>  SET @doc ='
    < root> 
      < Customer cid= "C1" name="Janine" city="Issaquah"> 
          < Order oid="O1" date="1/20/1996" amount="3.5" /> 
          < Order oid="O2" date="4/30/1997" amount="13.4"> Customer was very satisfied
          < /Order> 
       < /Customer> 
       < Customer cid="C2" name="Ursula" city="Oelde" > 
          < Order oid="O3" date="7/14/1999" amount="100" note="Wrap it blue 
                 white red"> 
                < Urgency> Important< /Urgency> 
                Happy Customer.
          < /Order> 
          < Order oid="O4" date="1/20/1996" amount="10000"/> 
       < /Customer> 
    < /root> 
    '
    -- Create an internal representation of the XML document.
    EXEC sp_xml_preparedocument.nbsp@idoc OUTPUT, @doc-- Execute a SELECT statement using OPENXML rowset provider.
    SELECT *
    FROM OPENXML (@idoc, '/root/Customer/Order', 1)
          WITH (oid     char(5), 
                amount  float, 
                comment ntext 'text()')
    EXEC sp_xml_removedocument.nbsp@idoc ???????
      

  19.   

    /**********************Excel导到Txt****************************************/
    想用
    select * into opendatasource(...) from opendatasource(...)
    实现将一个Excel文件内容导入到一个文本文件假设Excel中有两列,第一列为姓名,第二列为很行帐号(16位)
    且银行帐号导出到文本文件后分两部分,前8位和后8位分开。
    邹健:
    如果要用你上面的语句插入的话,文本文件必须存在,而且有一行:姓名,银行账号1,银行账号2
    然后就可以用下面的语句进行插入
    注意文件名和目录根据你的实际情况进行修改.insert into
    opendatasource('MICROSOFT.JET.OLEDB.4.0'
    ,'Text;HDR=Yes;DATABASE=C:\'
    )...[aa#txt]
    --,aa#txt)
    --*/
    select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8) 
    from 
    opendatasource('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;IMEX=2;DATABASE=c:\a.xls'
    --,Sheet1$)
    )...[Sheet1$] 如果你想直接插入并生成文本文件,就要用bcpdeclare @sql varchar(8000),@tbname varchar(50)--首先将excel表内容导入到一个全局临时表
    select @tbname='[##temp'+cast(newid() as varchar(40))+']'
     ,@sql='select 姓名,银行账号1=left(银行账号,8),银行账号2=right(银行账号,8) 
     into '+@tbname+' from 
    opendatasource(''MICROSOFT.JET.OLEDB.4.0''
    ,''Excel 5.0;HDR=YES;IMEX=2;DATABASE=c:\a.xls''
    )...[Sheet1$]'
    exec(@sql)--然后用bcp从全局临时表导出到文本文件
    set @sql='bcp "'+@tbname+'" out "c:\aa.txt" /S"(local)" /P"" /c'
    exec master..xp_cmdshell @sql--删除临时表
    exec('drop table '+@tbname)
    /********************导整个数据库*********************************************/用bcp实现的存储过程
    /*
     实现数据导入/导出的存储过程
             根据不同的参数,可以实现导入/导出整个数据库/单个表
     调用示例:
    --导出调用示例
    ----导出单个表
    exec file2table 'zj','','','xzkh_sa..地区资料','c:\zj.txt',1
    ----导出整个数据库
    exec file2table 'zj','','','xzkh_sa','C:\docman',1--导入调用示例
    ----导入单个表
    exec file2table 'zj','','','xzkh_sa..地区资料','c:\zj.txt',0
    ----导入整个数据库
    exec file2table 'zj','','','xzkh_sa','C:\docman',0*/
    if exists(select 1 from sysobjects where name='File2Table' and objectproperty(id,'IsProcedure')=1)
     drop procedure File2Table
    go
    create procedure File2Table
    @servername varchar(200)  --服务器名
    ,@username varchar(200)   --用户名,如果用NT验证方式,则为空''
    ,@password varchar(200)   --密码
    ,@tbname varchar(500)   --数据库.dbo.表名,如果不指定:.dbo.表名,则导出数据库的所有用户表
    ,@filename varchar(1000)  --导入/导出路径/文件名,如果@tbname参数指明是导出整个数据库,则这个参数是文件存放路径,文件名自动用表名.txt
    ,@isout bit      --1为导出,0为导入
    as
    declare @sql varchar(8000)if @tbname like '%.%.%' --如果指定了表名,则直接导出单个表
    begin
     set @sql='bcp '+@tbname
      +case when @isout=1 then ' out ' else ' in ' end
      +' "'+@filename+'" /w'
      +' /S '+@servername
      +case when isnull(@username,'')='' then '' else ' /U '+@username end
      +' /P '+isnull(@password,'')
     exec master..xp_cmdshell @sql
    end
    else
    begin --导出整个数据库,定义游标,取出所有的用户表
     declare @m_tbname varchar(250)
     if right(@filename,1)< > '\' set @filename=@filename+'\' set @m_tbname='declare #tb cursor for select name from '+@tbname+'..sysobjects where xtype=''U'''
     exec(@m_tbname)
     open #tb
     fetch next from #tb into @m_tbname
     while @@fetch_status=0
     begin
      set @sql='bcp '+@tbname+'..'+@m_tbname
       +case when @isout=1 then ' out ' else ' in ' end
       +' "'+@filename+@m_tbname+'.txt " /w'
       +' /S '+@servername
       +case when isnull(@username,'')='' then '' else ' /U '+@username end
       +' /P '+isnull(@password,'')
      exec master..xp_cmdshell @sql
      fetch next from #tb into @m_tbname
     end
     close #tb
     deallocate #tb 
    end
    go
    /************* Oracle **************/
    EXEC sp_addlinkedserver 'OracleSvr', 
       'Oracle 7.3', 
       'MSDAORA', 
       'ORCLDB'
    GOdelete from openquery(mailser,'select *  from yulin')select *  from openquery(mailser,'select *  from yulin')update openquery(mailser,'select * from  yulin where id=15')set disorder=555,catago=888insert into openquery(mailser,'select disorder,catago from  yulin')values(333,777) 补充:对于用bcp导出,是没有字段名的.用openrowset导出,需要事先建好表.用openrowset导入,除ACCESS及EXCEL外,均不支持非本机数据导入 从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句:/*===================================================================*/
    --如果接受数据导入的表已经存在
    insert into 表 select * from 
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;DATABASE=c:\1.xls',sheet1$)--如果导入数据并生成表
    select * into 表 from 
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;DATABASE=c:\1.xls',sheet1$)
    /*===================================================================*/
    --如果从SQL数据库中,导出数据到Excel,如果Excel文件已经存在,而且已经按照要接收的数据创建好表头,就可以简单的用:
    insert into OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)
    select * from 表
    --如果Excel文件不存在,也可以用BCP来导成类Excel的文件,注意大小写:
    --导出表的情况
    EXEC master..xp_cmdshell 'bcp 数据库名.dbo.表名 out "c:\test.xls" /c -/S"服务器名" /U"用户名" -P"密码"'--导出查询的情况
    EXEC master..xp_cmdshell 'bcp "SELECT au_fname, au_lname FROM pubs..authors ORDER BY au_lname" queryout "c:\test.xls" /c -/S"服务器名" /U"用户名" -P"密码"'