• SQL语句导入导出大全[收集]


    SQL语句导入导出大全[收集]
    正巧这两天要用到这个,上网找到一个,回来自己检测一下:
    /*******  导出到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
    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 @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 @idoc

    ???????

    /**********************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$]

    如果你想直接插入并生成文本文件,就要用bcp

    declare @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'
    GO

    delete 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=888

    insert into openquery(mailser,'select disorder,catago from  yulin')values(333,777)

    补充:

    对于用bcp导出,是没有字段名的.

    用openrowset导出,需要事先建好表.

    用openrowset导入,除ACCESS及EXCEL外,均不支持非本机数据导入

    posted on 2005-08-02 23:03 任搏软 阅读(1133) 评论(4)  编辑 收藏 引用 网摘 所属分类: DataBase
     
    FeedBack:
    # re: SQL语句导入导出大全[收集] 2005-08-06 00:32 任搏软
    熟悉SQL SERVER 2000的数据库管理员都知道,其DTS可以进行数据的导入导出,其实,我们也可以使用

    Transact-SQL语句进行导入导出操作。在Transact-SQL语句中,我们主要使用OpenDataSource函数、

    OPENROWSET 函数,关于函数的详细说明,请参考SQL联机帮助。利用下述方法,可以十分容易地实现SQL

    SERVER、ACCESS、EXCEL数据转换,详细说明如下:


    一、SQL SERVER 和ACCESS的数据导入导出

    常规的数据导入导出:

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

      1在SQL SERVER企业管理器中的Tools(工具)菜单上,选择Data Transformation

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

      3在Choose a Data Source(选择数据源)对话框中选择Microsoft Access as the Source,然后键

    入你的.mdb数据库(.mdb文件扩展名)的文件名或通过浏览寻找该文件。

      4在Choose a Destination(选择目标)对话框中,选择Microsoft OLE DB Prov ider for SQL 

    Server,选择数据库服务器,然后单击必要的验证方式。

      5在Specify Table Copy(指定表格复制)或Query(查询)对话框中,单击Copy tables(复制表格

    )。

    6在Select Source Tables(选择源表格)对话框中,单击Select All(全部选定)。下一步,完成。

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

    1. 在SQL SERVER里查询access数据:

    -- ======================================================

    SELECT *

    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',

    'Data Source="c:\DB.mdb";User ID=Admin;Password=')...表名

    2.将access导入SQL server

    -- ======================================================

    在SQL SERVER 里运行:

    SELECT *

    INTO newtable

    FROM OPENDATASOURCE ('Microsoft.Jet.OLEDB.4.0',

    'Data Source="c:\DB.mdb";User ID=Admin;Password=' )...表名


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

    -- ======================================================

    在SQL SERVER 里运行:

    insert into OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',

    'Data Source=" c:\DB.mdb";User ID=Admin;Password=')...表名

    (列名1,列名2)

    select 列名1,列名2 from sql表

    实例:

    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的数据导入导出

    1、在SQL SERVER里查询Excel数据:

    -- ======================================================

    SELECT *

    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',

    'Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...

    [Sheet1$]

    下面是个查询的示例,它通过用于 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的数据导入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$]

    实例:

    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中查询到的数据导成一个Excel文件

    -- ======================================================

    T-SQL代码:

    EXEC master..xp_cmdshell 'bcp 库名.dbo.表名out c:\Temp.xls -c -q -S"servername" -U"sa" -P""'

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

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

    实例: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中应用ADO导出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 库名.dbo.表名" queryout

    E:\DT.xls -c -Sservername -Usa -Ppassword'"


    4、在SQL SERVER里往Excel插入数据:

    -- ======================================================

    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')


    总结:利用以上语句,我们可以方便地将SQL SERVER、ACCESS和EXCEL电子表格软件中的数据进行转换,

    为我们提供了极大方便!
      回复
      
    # re: SQL语句导入导出大全[收集] 2005-08-06 00:37 任搏软
    ASP导出Excel数据的四种方法
    来源: aspsky 作者: tonny
      一、使用OWC

      什么是OWC?

      OWC是Office Web Compent的缩写,即Microsoft的Office Web组件,它为在Web中绘制图形提供了灵

    活的同时也是最基本的机制。在一个intranet环境中,如果可以假设客户机上存在特定的浏览器和一些功

    能强大的软件(如IE5和Office 2000),那么就有能力利用Office Web组件提供一个交互式图形开发环境

    。这种模式下,客户端工作站将在整个任务中分担很大的比重。

    <%Option Explicit
    Class ExcelGen
    Private objSpreadsheet
    Private iColOffset

    Private iRowOffset
    Sub Class_Initialize()
    Set objSpreadsheet = Server.CreateObject("OWC.Spreadsheet")
    iRowOffset = 2
    iColOffset = 2
    End Sub

    Sub Class_Terminate()
    Set objSpreadsheet = Nothing 'Clean up
    End Sub

    Public Property Let ColumnOffset(iColOff)
    If iColOff > 0 then
    iColOffset = iColOff
    Else
    iColOffset = 2
    End If
    End Property

    Public Property Let RowOffset(iRowOff)
    If iRowOff > 0 then
    iRowOffset = iRowOff
    Else
    iRowOffset = 2
    End If
    End Property Sub GenerateWorksheet(objRS)
    'Populates the Excel worksheet based on a Recordset's contents
    'Start by displaying the titles
    If objRS.EOF then Exit Sub
    Dim objField, iCol, iRow
    iCol = iColOffset
    iRow = iRowOffset
    For Each objField in objRS.Fields
    objSpreadsheet.Cells(iRow, iCol).Value = objField.Name
    objSpreadsheet.Columns(iCol).AutoFitColumns
    '设置Excel表里的字体
    objSpreadsheet.Cells(iRow, iCol).Font.Bold = True
    objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
    objSpreadsheet.Cells(iRow, iCol).Font.Size = 10
    objSpreadsheet.Cells(iRow, iCol).Halignment = 2 '居中
    iCol = iCol + 1
    Next 'objField
    'Display all of the data
    Do While Not objRS.EOF
    iRow = iRow + 1
    iCol = iColOffset
    For Each objField in objRS.Fields
    If IsNull(objField.Value) then
    objSpreadsheet.Cells(iRow, iCol).Value = ""
    Else
    objSpreadsheet.Cells(iRow, iCol).Value = objField.Value
    objSpreadsheet.Columns(iCol).AutoFitColumns
    objSpreadsheet.Cells(iRow, iCol).Font.Bold = False
    objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
    objSpreadsheet.Cells(iRow, iCol).Font.Size = 10
    End If
    iCol = iCol + 1
    Next 'objField
    objRS.MoveNext
    Loop
    End Sub Function SaveWorksheet(strFileName)

    'Save the worksheet to a specified filename
    On Error Resume Next
    Call objSpreadsheet.ActiveSheet.Export(strFileName, 0)
    SaveWorksheet = (Err.Number = 0)
    End Function
    End Class

    Dim objRS
    Set objRS = Server.CreateObject("ADODB.Recordset")
    objRS.Open "SELECT * FROM xxxx", "Provider=SQLOLEDB.1;Persist Security

    Info=True;User ID=xxxx;Password=xxxx;Initial Catalog=xxxx;Data source=xxxx;"
    Dim SaveName
    SaveName = Request.Cookies("savename")("name")
    Dim objExcel
    Dim ExcelPath
    ExcelPath = "Excel\" & SaveName & ".xls"
    Set objExcel = New ExcelGen
    objExcel.RowOffset = 1
    objExcel.ColumnOffset = 1
    objExcel.GenerateWorksheet(objRS)
    If objExcel.SaveWorksheet(Server.MapPath(ExcelPath)) then
    'Response.Write "<html><body bgcolor='gainsboro' text='#000000'>已保存为Excel文件.

    <a href='" & server.URLEncode(ExcelPath) & "'>下载</a>"
    Else
    Response.Write "在保存过程中有错误!"
    End If
    Set objExcel = Nothing
    objRS.Close
    Set objRS = Nothing
    %>

      二、用Excel的Application组件在客户端导出到Excel或Word

      注意:两个函数中的“data“是网页中要导出的table的 id

    <input type="hidden" name="out_word" onclick="vbscript:buildDoc" value="导出到word"

    class="notPrint">
    <input type="hidden" name="out_excel" onclick="AutomateExcel();" value="导出到excel"

    class="notPrint">

      导出到Excel代码

    <SCRIPT LANGUAGE="javascript">
    <!--
    function AutomateExcel()
    {
    // Start Excel and get Application object.
    var oXL = new ActiveXObject("Excel.Application");
    // Get a new workbook.
    var oWB = oXL.Workbooks.Add();
    var oSheet = oWB.ActiveSheet;
    var table = document.all.data;
    var hang = table.rows.length;

    var lie = table.rows(0).cells.length;

    // Add table headers going cell by cell.
    for (i=0;i<hang;i++)
    {
    for (j=0;j<lie;j++)
    {
    oSheet.Cells(i+1,j+1).value = table.rows(i).cells(j).innerText;
    }

    }
    oXL.Visible = true;
    oXL.UserControl = true;
    }
    //-->
    </SCRIPT>

      导出到Word代码

    <script language="vbscript">
    Sub buildDoc
    set table = document.all.data
    row = table.rows.length
    column = table.rows(1).cells.length

    Set objWordDoc = CreateObject("Word.Document")

    objWordDoc.Application.Documents.Add theTemplate, False
    objWordDoc.Application.Visible=True

    Dim theArray(20,10000)
    for i=0 to row-1
    for j=0 to column-1
    theArray(j+1,i+1) = table.rows(i).cells(j).innerTEXT
    next
    next
    objWordDoc.Application.ActiveDocument.Paragraphs.Add.Range.InsertBefore("综合查询结果集") //

    显示表格标题

    objWordDoc.Application.ActiveDocument.Paragraphs.Add.Range.InsertBefore("")
    Set rngPara = objWordDoc.Application.ActiveDocument.Paragraphs(1).Range
    With rngPara
    .Bold = True //将标题设为粗体
    .ParagraphFormat.Alignment = 1 //将标题居中
    .Font.Name = "隶书" //设定标题字体
    .Font.Size = 18 //设定标题字体大小
    End With
    Set rngCurrent = objWordDoc.Application.ActiveDocument.Paragraphs(3).Range
    Set tabCurrent = ObjWordDoc.Application.ActiveDocument.Tables.Add(rngCurrent,row,column)

    for i = 1 to column

    objWordDoc.Application.ActiveDocument.Tables(1).Rows(1).Cells(i).Range.InsertAfter theArray

    (i,1)
    objWordDoc.Application.ActiveDocument.Tables(1).Rows(1).Cells

    (i).Range.ParagraphFormat.alignment=1
    next
    For i =1 to column
    For j = 2 to row
    objWordDoc.Application.ActiveDocument.Tables(1).Rows(j).Cells(i).Range.InsertAfter theArray

    (i,j)
    objWordDoc.Application.ActiveDocument.Tables(1).Rows(j).Cells

    (i).Range.ParagraphFormat.alignment=1
    Next
    Next

    End Sub
    </SCRIPT>

      三、直接在IE中打开,再存为EXCEL文件

      把读出的数据用<table>格式,在网页中显示出来,同时,加上下一句即可把EXCEL表在客客户端显

    示。

    <%response.ContentType ="application/vnd.ms-excel"%>

      注意:显示的页面中,只把<table>输出,最好不要输出其他表格以外的信息。

      四、导出以半角逗号隔开的csv

      用fso方法生成文本文件的方法,生成一个扩展名为csv文件。此文件,一行即为数据表的一行。生成

    数据表字段用半角逗号隔开。(有关fso生成文本文件的方法,在此就不做介绍了)

      CSV文件介绍 (逗号分隔文件)

      选择该项系统将创建一个可供下载的CSV 文件; CSV是最通用的一种文件格式,它可以非常容易地被

    导入各种PC表格及数据库中。

      请注意即使选择表格作为输出格式,仍然可以将结果下载CSV文件。在表格输出屏幕的底部,显示有

    "CSV 文件"选项,点击它即可下载该文件。

      如果您把浏览器配置为将您的电子表格软件与文本(TXT)/逗号分隔文件(CSV) 相关联,当您下载

    该文件时,该文件将自动打开。下载下来后,如果本地已安装EXCEL,点击此文件,即可自动用EXCEL软件

    打开此文件。  回复
      
    # re: SQL语句导入导出大全[收集] 2005-08-06 00:38 任搏软
    标题 导入/导出Excel zjcxc(原作)

    关键字 导入/导出Excel

    从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句:

    /*===================================================================*/
    --如果接受数据导入的表已经存在
    insert into 表 select * from
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)

    --如果导入数据并生成表
    select * into 表 from
    OPENROWSET('MICROSOFT.JET.OLEDB.4.0'
    ,'Excel 5.0;HDR=YES;DATABASE=c:\test.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"密码"'

    说明.

    c:\test.xls 为导入/导出的Excel文件名.
    sheet1$ 为Excel文件的工作表名,一般要加上$才能正常使用.

    下面是导出真正Excel文件的方法:


    /*--数据导出EXCEL

    导出表中的数据到Excel,包含字段名,文件为真正的Excel文件
    ,如果文件不存在,将自动创建文件
    ,如果表不存在,将自动创建表
    基于通用性考虑,仅支持导出标准数据类型
    ---*/

    /*--调用示例

    p_exporttb @tbname='地区资料',@path='c:\',@fname='aa.xls'
    --*/
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_exporttb]') and

    OBJECTPROPERTY(id, N'IsProcedure') = 1)
    drop procedure [dbo].[p_exporttb]
    GO

    create proc p_exporttb
    @tbname sysname, --要导出的表名,注意只能是表名/视图名
    @path nvarchar(1000), --文件存放目录
    @fname nvarchar(250)='' --文件名,默认为表名
    as
    declare @err int,@src nvarchar(255),@desc nvarchar(255),@out int
    declare @obj int,@constr nvarchar(1000),@sql varchar(8000),@fdlist varchar(8000)

    --参数检测
    if isnull(@fname,'')='' set @fname=@tbname+'.xls'

    --检查文件是否已经存在
    if right(@path,1)<>'\' set @path=@path+'\'
    create table #tb(a bit,b bit,c bit)
    set @sql=@path+@fname
    insert into #tb exec master..xp_fileexist @sql

    --数据库创建语句
    set @sql=@path+@fname
    if exists(select 1 from #tb where a=1)
    set @constr='DRIVER={Microsoft Excel Driver (*.xls)};DSN='''';READONLY=FALSE'
    +';CREATE_DB="mailto:'+@sql+'%22;DBQ='+@sql
    else
    set @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties="Excel 5.0;HDR=YES'
    +';DATABASE='+@sql+'"'

    --连接数据库
    exec @err=sp_oacreate 'adodb.connection',@obj out
    if @err<>0 goto lberr

    exec @err=sp_oamethod @obj,'open',null,@constr
    if @err<>0 goto lberr

    --创建表的SQL
    select @sql='',@fdlist=''
    select @fdlist=@fdlist+','+a.name
    ,@sql=@sql+',['+a.name+'] '
    +case when b.name in('char','nchar','varchar','nvarchar') then
    'text('+cast(case when a.length>255 then 255 else a.length end as varchar)+')'
    when b.name in('tynyint','int','bigint','tinyint') then 'int'
    when b.name in('smalldatetime','datetime') then 'datetime'
    when b.name in('money','smallmoney') then 'money'
    else b.name end
    FROM syscolumns a left join systypes b on a.xtype=b.xusertype
    where b.name not in

    ('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')
    and object_id(@tbname)=id
    select @sql='create table ['+@tbname
    +']('+substring(@sql,2,8000)+')'
    ,@fdlist=substring(@fdlist,2,8000)

    exec @err=sp_oamethod @obj,'execute',@out out,@sql
    if @err<>0 goto lberr

    exec @err=sp_oadestroy @obj

    --导入数据
    set @sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''Excel 5.0;HDR=YES
    ;DATABASE='+@path+@fname+''',['+@tbname+'$])'

    exec('insert into '+@sql+'('+@fdlist+') select '+@fdlist+' from '+@tbname)

    return

    lberr:
    exec sp_oageterrorinfo 0,@src out,@desc out
    lbexit:
    select cast(@err as varbinary(4)) as 错误号
    ,@src as 错误源,@desc as 错误描述
    select @sql,@constr,@fdlist
    go

    *--数据导出EXCEL

    导出查询中的数据到Excel,包含字段名,文件为真正的Excel文件
    ,如果文件不存在,将自动创建文件
    ,如果表不存在,将自动创建表
    基于通用性考虑,仅支持导出标准数据类型
    --*/

    /*--调用示例

    p_exporttb @sqlstr='select * from 地区资料'
    ,@path='c:\',@fname='aa.xls',@sheetname='地区资料'
    --*/
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_exporttb]') and

    OBJECTPROPERTY(id, N'IsProcedure') = 1)
    drop procedure [dbo].[p_exporttb]
    GO

    create proc p_exporttb
    @sqlstr sysname, --查询语句,如果查询语句中使用了order by ,请加上top 100 percent,注意,如果导

    出表/视图,用上面的存储过程
    @path nvarchar(1000), --文件存放目录
    @fname nvarchar(250), --文件名
    @sheetname varchar(250)='' --要创建的工作表名,默认为文件名
    as
    declare @err int,@src nvarchar(255),@desc nvarchar(255),@out int
    declare @obj int,@constr nvarchar(1000),@sql varchar(8000),@fdlist varchar(8000)

    --参数检测
    if isnull(@fname,'')='' set @fname='temp.xls'
    if isnull(@sheetname,'')='' set @sheetname=replace(@fname,'.','#')

    --检查文件是否已经存在
    if right(@path,1)<>'\' set @path=@path+'\'
    create table #tb(a bit,b bit,c bit)
    set @sql=@path+@fname
    insert into #tb exec master..xp_fileexist @sql

    --数据库创建语句
    set @sql=@path+@fname
    if exists(select 1 from #tb where a=1)
    set @constr='DRIVER={Microsoft Excel Driver (*.xls)};DSN='''';READONLY=FALSE'
    +';CREATE_DB="mailto:'+@sql+'%22;DBQ='+@sql
    else
    set @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties="Excel 5.0;HDR=YES'
    +';DATABASE='+@sql+'"'

    --连接数据库
    exec @err=sp_oacreate 'adodb.connection',@obj out
    if @err<>0 goto lberr

    exec @err=sp_oamethod @obj,'open',null,@constr
    if @err<>0 goto lberr

    --创建表的SQL
    declare @tbname sysname
    set @tbname='##tmp_'+convert(varchar(38),newid())
    set @sql='select * into ['+@tbname+'] from('+@sqlstr+') a'
    exec(@sql)

    select @sql='',@fdlist=''
    select @fdlist=@fdlist+','+a.name
    ,@sql=@sql+',['+a.name+'] '
    +case when b.name in('char','nchar','varchar','nvarchar') then
    'text('+cast(case when a.length>255 then 255 else a.length end as varchar)+')'
    when b.name in('tynyint','int','bigint','tinyint') then 'int'
    when b.name in('smalldatetime','datetime') then 'datetime'
    when b.name in('money','smallmoney') then 'money'
    else b.name end
    FROM tempdb..syscolumns a left join tempdb..systypes b on a.xtype=b.xusertype
    where b.name not in

    ('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')
    and a.id=(select id from tempdb..sysobjects where name=@tbname)
    select @sql='create table ['+@sheetname
    +']('+substring(@sql,2,8000)+')'
    ,@fdlist=substring(@fdlist,2,8000)

    exec @err=sp_oamethod @obj,'execute',@out out,@sql
    if @err<>0 goto lberr

    exec @err=sp_oadestroy @obj

    --导入数据
    set @sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''Excel 5.0;HDR=YES
    ;DATABASE='+@path+@fname+''',['+@sheetname+'$])'

    exec('insert into '+@sql+'('+@fdlist+') select '+@fdlist+' from ['+@tbname+']')

    set @sql='drop table ['+@tbname+']'
    exec(@sql)
    return

    lberr:
    exec sp_oageterrorinfo 0,@src out,@desc out
    lbexit:
    select cast(@err as varbinary(4)) as 错误号
    ,@src as 错误源,@desc as 错误描述
    select @sql,@constr,@fdlist
    go
      回复
      
    # re: SQL语句导入导出大全[收集] 2005-08-07 22:19 任搏软
    --ACCESS中操作 SQL Server 数据库,需要你能连接远程的 SQL Server 服务器:
    然后打开ACCESS数据库(用ACCESS打开/程序中打开均可)
    --导入数据到ACCESS数据库中
    --如果是下载SQL的数据(表已经存在的情况)
    insert into 表名
    SELECT *
    FROM [ODBC;Driver=SQL Server;Server=远程SQL服务器名;Uid=用户名;Pwd=密码;database=数据库名].

    表名
    --如果是下载SQL的数据(表不存在的情况)
    SELECT * into 表名
    FROM [ODBC;Driver=SQL Server;Server=远程SQL服务器名;Uid=用户名;Pwd=密码;database=数据库名].

    表名
    --如果是上传数据库到SQL(表已经存在的情况):
    insert into [ODBC;Driver=SQL Server;Server=远程SQL服务器名;Uid=用户名;Pwd=密码;database=数据

    库名].表名
    SELECT * FROM 表名
    --如果是上传数据库到SQL(表不存在的情况):
    SELECT * into [ODBC;Driver=SQL Server;Server=远程SQL服务器名;Uid=用户名;Pwd=密码;database=数

    据库名].表名
    FROM 表名
    --*/  

     
     
     
     
    Re:SQL语句导入导出大全[收集]
    [ 2007-5-20 17:33:03 | By: me(游客) ]
     
    目的
    有时客户出于某种原因会要求我们能将系统的资料导出为excel或则access这种他们熟悉的文件格式。由于ie的打印控制比较困难,我们制作打印的时候也可以考虑提供excel文件格式的下载,让客户在excel中调整格式后打印。出于这些原因我们可能需要在程序中提供excel文件格式的数据下载。

    途径
    导出为excel文件有不少方法,例如:
    1. 使用 excel automation server循环生成。
    2. 生成定界符文件然后使用excel打开,保存为xls文件。
    3. 使用xml文件作中间过程文件,然后使用excel的openxml方法打开(需要excel2002以上版本)。
    4. 使用ado.net。
    我在这里要使用的方法是第四种,利用ado.net来转换。

    基本思路
    我按照这么几步来实行我的计划:
    1. 将sql server中的资料读入dataset。
    2. 使用oledb新建一个表(在excel文件中就是一个workbooks)。
    3. 通过循环将dataset的内容插入刚才建立的表中。
    4. 提供刚才生成的文件的下载。
    5. 删除临时生成的excel文件。
    这里有个问题,就是临时生成的excel文件的命名冲突问题,我使用guid来生成唯一名称。

    范例代码
    准备工作,我准备将虚拟目录下的temp作为临时文件目录。

    string urlpath = httpcontext.current.request.applicationpath + "/temp/";

    string physicpath = httpcontext.current.server.mappath(urlpath);

    string filename = guid.newguid() + ".xls";

    string connstring = "provider=microsoft.jet.oledb.4.0;data source=" + physicpath + filename +";extended properties=excel 8.0;";

    oledbconnection objconn = new oledbconnection(connstring);
    oledbcommand objcmd = new oledbcommand();
    objcmd.connection = objconn;

    建立表结构

    objcmd.commandtext = @"create table 客户信息
    (
    客户名 varchar,
    注册时间 varchar
    )
    ";

    objcmd.executenonquery();

    插入新数据

    //建立插入动作的command
    objcmd.commandtext = "insert into 客户资料(客户名, 生日) values (@customername, @registertime)";
    objcmd.parameters.add(new oledbparameter("@customername", oledbtype.varchar));
    objcmd.parameters.add(new oledbparameter("@registertime", oledbtype.varchar));


    //遍历dataset将数据插入新建的excel文件中,customerinfo为我们从数据库中读到的数据
    foreach (datarow row in customerinfo.tables[0].rows)
    {
    for (int i=0; i<parm.length; i++)
    {
    parm[i].value = row[i];
    }
    objcmd.executenonquery();
    }

    提供下载

    httpresponse response = httpcontext.current.response;
    response.clear();
    response.writefile(path + filename);
    string httpheader="attachment;filename=backup.xls";
    response.appendheader("content-disposition", httpheader);
    response.flush();

    system.io.file.delete(path + filename);//删除临时文件
    response.end();
  • 相关阅读:
    24. Swap Nodes in Pairs
    23. Merge k Sorted Lists
    shell脚本报错:"[: =: unary operator expected"
    一种用 数组元素 指定 所调函数 的方法
    阻塞 非阻塞
    Linux open() 一个函数,两个函数原型
    QT 执行windows cmd 命令并读取结果
    Qt5 escape spaces in path
    获取磁盘的 总容量,空余容量,已用容量 【windows】
    通过进程名称,获取其路径
  • 原文地址:https://www.cnblogs.com/juan/p/1429016.html
Copyright © 2020-2023  润新知