从SQLSERVER中导出查询数据至Excel
【Sqlserver】查询结果导出excel
【 Sqlserver】查询结果导出 excel
1.右键数据库——》任务——》导出数据,打开SQL Server导入和导出向导; 2.选择当前数据库,填写用户名,密码,下一步; 3.选择目标类型要传输的数据(W),可以直接按W,下一步; 5.写入查询SQL语句,点击分析检测语句,下一步; 6.编辑映射关系,预览效果,下一步; 7.下一步,至完成;
注:这种方式可以解决直接复制查询结果时,如身份证号等长数字字符串,在excel中自动转成数字型,导致显示不正确。
SQLServer读取及导入Excel数据
SQLServer读取及导⼊Excel数据⼀、引⾔使⽤SQL Server的OPENROWSET及OPENDATASOURCE函数,可以像查询数据表⼀样来读取Excel数据。
但是,要想让这两个函数能正常运⾏,可不是那么容易,假如没理解或没配置好的话,⼀路的报错会让你怀疑⼈⽣。
⼆、配置2.1、组件安装要想使⽤OPENROWSET及OPENDATASOURCE函数来读取Excel数据,⾸先要在⽬标的SQL Server主机上安装AccessDatabaseEngine组件。
1)换句话说:假如要操作的数据库是在本地的,那我在本地安装AccessDatabaseEngine即可;假如要操作的数据库安装在远程的服务器上,那么需在远程的服务器上安装AccessDatabaseEngine。
2)需要说明的是,读取Excel数据,只需安装AccessDatabaseEngine,并不⼀定要安装Office。
3)依⽬标的SQL Server主机的操作系统位数,来对应安装AccessDatabaseEngine版本。
本处Excel是2013版本(.xlsx),需安装Microsoft Access Database Engine 2010 Redistributable。
2.2、服务配置在⽬标的SQL Server主机上,Win+R调出运⾏,输⼊services.msc调出服务。
将SQL Server (MSSQLSERVER)、SQL Full-text Filter Daemon Launcher (MSSQLSERVER)两个服务的登录⾝份,改为本地系统账户。
2.3、参数配置在⽬标的SQL Server上打开查询分析器,执⾏以下语句:--1、开启导⼊功能(查看参数:exec sp_configure)exec sp_configure 'show advanced options',1reconfigureexec sp_configure 'Ad Hoc Distributed Queries',1reconfigure--2、允许在进程中使⽤ACE.OLEDB.12.0exec master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'AllowInProcess', 1--3、允许动态参数exec master.dbo.sp_MSset_oledb_prop N'Microsoft.ACE.OLEDB.12.0', N'DynamicParameters', 12.3.1、开启导⼊功能对应的系统界⾯:2.3.2、允许在进程中使⽤ACE.OLEDB.12.0及允许动态参数对应的系统界⾯:三、测试3.1、测试语句在⽬标的SQL Server上打开查询分析器,执⾏以下语句:--1、使⽤查询分析器查询EXCEL--注意1:若连接的是本机的数据库,E:\EDI\年度返利费⽤表.xlsx指的是本机的⽂件路径。
Excel2010获取外部数据(通过查询语句获取SQL数据库数据)
Excel 2010 获取外部数据(通过查询语句获取SQL数据库数据)
1、建立外部数据连接
数据-自其它来源-来自SQL Server,填写服务器名称、数据库sa用户名称、密码,下一步。
2、选择数据库,不要选择连接到指定表格,下一步。
3、填写文件名、说明、友好名称,完成。
对于出现的要求立即执行该连接的窗口取消即可
4、修改连接属性,填写SQL查询语句。
数据-现有连接,选择刚刚建立的连接,右键-编辑连接属性(如果因为刚才没有执行,不能使用右键,就直接双击执行,输入密码后确定,单击右下角属性。
)
在定义选项卡里面,将命令类型修改为SQL,命令文本里面输入对应的查询语句即可。
命令文本支持变量定义、注释,select语句仅支持一个,如果输入两个select语句,仅执行第一个。
不支持VBA里面的直接获取电子表格单元格数值(如cells(2,5)、range(“A2”).value),也就是说这里面支持的是SQL语句,不是VBA语句。
在该处可以使用“导出链接文件”把设计好的连接导出成文件进行保存,使用的时候使用连接文件后面的浏览按钮找到导出的文件直接使用即可。
(给客户使用的文件先测试好、导出,到客户电脑上面导入、修改连接字符串对应内容即可。
)
对于已经查询出来的数据,单击查询出的数据所在位置后,通过全部刷新-连接属性-定义或者链接-属性-定义可以对查询语句进行更改,更改后需要重新输入密码进行确认。
5、以后在数据-现有连接里面选择上对应的连接进行查询即可。
SQLSERVER对单个表部分数据导出导入
SQLSERVER将一个表中的部分查询数据导入另一个表中的方法:一、若源表与目标表同在一台机器上,直接写SQL语句即可:源表名:prdproductinfo_Source 称目标表名:PrdProductInfo_GoalINSERT INTO [PrdProductInfo_Goal]([productTypeCode],[productTypeName],[productModelId],[productModelCode],[productModelName],[productModelSpec],[productCode],[productName],[madePlace],[packageLanguage],[devicesNumber],[madeBatchNumber],[madeCommandOrder],[madeDate],[outDate])(select [productTypeCode],[productTypeName],[productModelId],[productModelCode],[productModelName],[productModelSpec],[productCode],[productName],[madePlace],[packageLanguage],[devicesNumber],[madeBatchNumber],[madeCommandOrder],[madeDate],[outDate] from prdproductinfo_Source)二、若源表与目标表不在同一台机器上,则可先将源表中的数据导出到EXCEL中,再将EXCEL中的数据导入到目标表中。
操作步骤如下:A、将源表中的数据导出到EXCEL中,步骤如下:1、选中数据库,右键-→任务-→点击“导出数据”,如下图:2、点击下图中的“下一步”:3、在“选择数据源”窗口,保持默认值,点击“下一步”:4、在“选择目标”窗口,在“目标”项的下拉框中,选择“Microsoft Excel”在Excel文件路径一栏后,点击“浏览”,选择要导出的Excel文件的存放路径及Excel名称。
SQL数据库表如何导入导出到EXCEL中
一.导出1.选择要导出的数据库表,右键选择“所有任务”,点击“所有任务”下的子菜单“Export Data…”进入“DTS Import/Export Wizard”窗口。
2.点击“下一步”,进入“Choose a Data Source”。
3.“Data Source”更改为“Microsoft OLE DB Provider for SQL Server”;“Server”更改为“笔记本(工控机)名称\WINCC”;下一步使用WINDOWS认证“Use Windows Authentication”;“Database”更改为“项目运行系统下的路径(例如:CC_BGSYJ_14_02_24_11_22_22R)”。
4. 点击“下一步”,进入“Choose a destination”。
5.“Destination”更改为“Microsoft Excel 97-2000”;“File name”建议更改为要导出的数据库表的名字,并指定保存的路径。
6.点击“下一步”,进入“Specify Table Copy Query”。
7. 点击“下一步”,进入“Select Source Table and Views”。
8.选择要导出的数据库表,然后点击“下一步”,进入“Save,Schedule,and replicate package”。
9. 点击“下一步”,“完成”,“确定”,“Done”,数据导出完成。
二.导入1.选择要导出的数据库表,右键选择“所有任务”,点击“所有任务”下的子菜单“Import Data…”进入“DTS Import/Export Wizard”窗口。
2. 点击“下一步”,进入“Choose a Data Source”。
3.“Data Source”更改为“Microsoft Excel 97-2000”;“File name”选择到指定路径下excel文档(重新制作或者以前导出的)。
SqlServer2008如何将数据表导出Excel文件?
SqlServer2008如何将数据表导出Excel⽂件?
1、⾸先在测试数据库中创建要导出Excel的数据
--创建⼀个民族表--
create table BdsNation(
Uid int not null,
Code varchar(10) not null,
Name varchar(20) not null,
Notes varchar(59) null
)
--插⼊数据
insert into BdsNation(Uid,Code,Name,NOtes)
values(1,'001','汉族','汉族123');
insert into BdsNation(Uid,Code,Name,NOtes)
values(2,'002','满族','满族123');
--查询数据--
select*from BdsNation;
2、导出数据的操作步骤
1)右键数据库,选择任务-->导出数据
2)选择数据源,默认Sql Server版本,默认导出数据库,点击下⼀步
3)选择导出⽬标,选择Microsoft Excel,选择要导出Excel路径,点击下⼀步
4)指定表复制或查询,第⼀种复制⼀个表数据,第⼆种可根据查询复制数据
5)选择源表和源视图,选择导出数据表,点击下⼀步
6)查看数据类型映射,点击下⼀步
7)保存并运⾏包,点击完成
8)点击完成,出现执⾏成功
3、导出后,打开Excel⽂件,查看结果。
sqlserver通过SQL语句导入excel
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
--导入excel d:\11.xls是文件
SELECT * INTO XLImport3 FROM OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0',
若是连ACCESS和EXCEL则变成:
select * from openrowset('Microsoft.Jet.OLEDB.4.0','IP地址或数据库路径(例:c:\xxx.mdb)';'用户名(一般默认为admin)';'密码(一般为空)',数据库名.dbo.表名)
select * from opendatasource('Microsoft.Jet.OLEDB.4.0','Data Source="数据库路径";User ID=admin;password=').DataBaseName.dbo.Table --连ACCESS
reconfigure
2 使用完成后,关闭Ad Hoc Distributed Queries:
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
'Data Source=D:\11.xls;Extended Properties=Excel 8.0')...[Sheet1$]
sqlserve 快速导出excel方法
SQL Server 是一种强大的关系型数据库管理系统,它可以帮助用户存储和管理大量结构化数据。
在实际工作中,我们经常需要将数据库中的数据导出到 Excel 表格中进行分析和处理。
本文将介绍 SQL Server 快速导出 Excel 的方法,希望对大家有所帮助。
1. 使用 SQL Server Management Studio 导出数据我们可以使用 SQL Server Management Studio(SSMS)自带的功能来快速导出数据到 Excel。
具体操作步骤如下:打开 SQL Server Management Studio,并连接到相应的数据库实例。
在 Object Explorer 中找到需要导出数据的数据库,展开该数据库,找到要导出数据的表。
右键点击该表,选择 "Tasks" -> "Export Data"。
在 "Wee to the SQL Server Import and Export Wizard" 窗口中,点击 "Next"。
在 "Choose a Data Source" 窗口中,选择数据源的类型,一般选择"SQL Server Native Client",然后选择要导出数据的数据库实例,输入数据库登入信息,点击 "Next"。
在 "Choose a Destination" 窗口中,选择目标数据源的类型为"Microsoft Excel",然后输入 Excel 文件的路径和名称,点击 "Next"。
在 "Specify Table Copy or Query" 窗口中,选择 "Copy data from one or more tables or views",然后选择要导出的表,点击 "Next"。
【IT专家】如何将SQLSERVER数据库中存放的图片数据导出至EXCEL表格中
本文由我司收集整编,推荐下载,如有疑问,请与我司联系如何将SQLSERVER数据库中存放的图片数据导出至EXCEL表格中在数据库应用的开发过程中,经常要在数据库中存储一些备注信息,而这些备注信息的内容一般较大,格式多样,有可能是图像、语音文件、视频文件等,在PB 中可以使用OLE的方法,也可以直接用脚本处理。
本文介绍用脚本来处理,数据库是ASA8的,附件里有表的设计,文中省略。
1、建立一个工作空间(workspace),取名为:blob。
2、建立一个应用(application),取名为:blob。
3、设计一个表blobtest,其字段定义如下:ColumnName DataType Width Null Comment No Integer No 号码Name Varchar 10 No 姓名Photo LongBinary Null 照片4、建立一窗口w_input,内置如下控件:控件名类型说明sle_no SingleLineEdit 输入号码sle_name SingleLineEdit 输入姓名cb_select_photo CommandButton 选择照片文件sle_photo SingleLineEdit 显示照片文件名cb_save CommandButton 保存记录(本文只有插入)cb_query CommandButton 查询cb_exit CommandButton 退出P_1 Picture 显示照片界面如下:5、编写脚本1)、cb_select_photo的clicked 事件:stringls_photofile stringls_named integerli_value //选择照片文件li_value=GetFileOpenName(“选择图片文件”, +ls_photofile,ls_named,”图片文件”, +”BMPFiles(*.BMP),*.BMP,” +”JPGFiles(*.JPG),*.JPG”) sle_photo.text=ls_photofile p_1.Picturename=ls_photofile 2)、cb_save的clicked事件:(本文只处理了新增记录,有兴趣的朋友可以完善他)long ll_no stringls_name stringls_photofile integer li_filenum integer li_loops integer li_counter long ll_filelen blob lb_read blob lb_picture Ifsle_no.text=‘‘orsle_name.text=‘‘orsle_photo.text=‘‘thenreturn ll_no=long(sle_no.text) //号码ls_name=sle_name.text //姓名ls_photofile=sle_photo.text//照片文件//插入记录,先写no,name字段Insertintoblobtest(no,name) values(:ll_no,:ls_name); Ifsqlca.sqlcode=-1then Rollback; Messagebox(‘插入记录出错’,Sqlca.Sqlerrtext) Return Else Commit; Endif //获取文件的大小ll_filelen=FileLength(ls_photofile) //打开文件li_filenum=FileOpen(ls_photofile,STREAMMODE!,READ!,LOCKREAD!) /*FileRead()函数不支持读取大于32K的文本,计算将使用FileRead函数的次数*/ IFll_filelen。
使用VB将SQL Server数据导出生成Excel表格
使用VB将SQLServer数据导出生成Excel表格作者:杨晓峰张茁来源:《硅谷》2009年第10期[摘要]使用VB将SQL Server和Excel结合起来处理数据会得到事半功倍的效果。
介绍设计一个VB程序将SQL Server中查询到的数据导出生成Excel表格的方法。
以解决非专业人员处理数据和阅读数据的问题,也解决SQL Server数据发布需要使用专用的SQL Server管理工具的不便之处。
[关键词]VB SQL Server Excel表格数据库中图分类号:TP3文献标识码:A文章编号:1671-7597(2009)0520058-01SQL Server作为微软在Windows系列平台上开发的数据库,一经推出就以其易用性得到了很多用户的青睐。
Excel是微软公司出品的Office系列办公软件中的一个组件,确切地说,它是一个电子表格软件,可以用来制作电子表格、完成许多复杂的数据运算,进行数据的分析和预测并且具有强大的制作图表的功能。
使用VB将SQL Server和Excel结合起来处理数据会得到事半功倍的效果。
下面将介绍如何设计一个VB程序将SQL Server中查询到的数据导出生成Excel表格。
一、利用ADO的数据库访问组件获取SQL Server中的数据1.在VB工程中新建一个模块LocalInfo,在模块中定义SqlConn的公共函数用以建立与SQL Server数据库的连接SqlCn对象,函数代码如下:Public Function SqlConn(ByVal Ser As String, Data As String, User As String, Pass As String) As BooleanOn Error Resume NextSet SqlCn = New ADODB.ConnectionSqlCn.CursorLocation = adUseClientSqlCn.ConnectionString = "Provider=SQLOLEDB;Server=" + Ser + ";Database=" + Data + ";User ID='" + User + "';Password='" + Pass + "';"SqlCn.OpenIf Err ThenErr.ClearSqlConn = False '数据库连接失败MsgBox "数据库连接失败!系统不能正常运行!" & Chr(13) & Chr(10) & "请进入“数据库设置”重新设定数据库参数!" & Chr(13) & Chr(10) & "或与系统管理员联系,完成后请重新启动该系统。
SQL导出到Excel的语句
SQL导出到Excel的语句从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句: /*============================================================= ======*/--如果接受数据导入的表已经存在insert into表select*fromOPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)--如果导入数据并生成表select*into表fromOPENROWSET('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]GOcreate proc p_exporttb@tbname sysname, --要导出的表名,注意只能是表名/视图名@path nvarchar(1000), --文件存放目录@fname nvarchar(250)=''--文件名,默认为表名asdeclare@err int,@src nvarchar(255),@desc nvarchar(255),@out int declare@obj int,@constr nvarchar(1000),@sqlvarchar(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+@fnameinsert into #tb exec master..xp_fileexist @sql--数据库创建语句set@sql=@path+@fnameif exists(select1from #tb where a=1)set@constr='DRIVER={Microsoft Excel Driver(*.xls)};DSN='''';READONLY=FALSE'+';CREATE_DB="'+@sql+'";DBQ='+ @sqlelseset@constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties="Excel 5.0;HDR=YES'+';DATABASE='+@sql+'"'--连接数据库exec@err=sp_oacreate 'adodb.connection',@obj outif@err<>0goto lberrexec@err=sp_oamethod @obj,'open',null,@constrif@err<>0goto lberr--创建表的SQLselect@sql='',@fdlist=''select@fdlist=@fdlist+','+,@sql=@sql+',['++']'+case when in('char','nchar','varchar','nvarchar') then 'text('+cast(case when a.length>255then255else a.length end as varchar)+')'when in('tynyint','int','bigint','tinyint') then'int' when in('smalldatetime','datetime') then'datetime' when in('money','smallmoney') then'money'else endFROM syscolumns a left join systypes b on a.xtype=b.xusertype where notin('image','text','uniqueidentifier','sql_variant','ntext','var binary','binary','timestamp') and object_id(@tbname)=idselect@sql='create table['+@tbname+']('+substring(@sql,2,8000)+')',@fdlist=substring(@f dlist,2,8000)exec@err=sp_oamethod @obj,'execute',@out out,@sqlif@err<>0goto lberrexec@err=sp_oadestroy @obj--导入数据set@sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''Excel5.0;HDR=YES;DATABASE='+@path+@fname+''',['+@tbname+'$])'exec('insert into '+@sql+'('+@fdlist+') select '+@fdlist+' from '+@tbname)returnlberr:exec sp_oageterrorinfo 0,@src out,@desc outlbexit:select cast(@err as varbinary(4)) as错误号,@src as错误源,@desc as错误描述select@sql,@constr,@fdlistgo。
sql_server_2008_导入导出数据大全
sql server 2008 导入导出数据大全/******* 导出到excelEXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:\temp1.xls -c -q - S"GNETDATA/GNETDATA" -U"sa" -P""'/*********** 导入ExcelSELECT *FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\test.xls";User ID=Admin;Password=;Extendedproperties=Excel5.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=;Extendedproperties=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=;Extendedproperties=Excel5.0')...xactions/********************** EXCEL导到远程SQLinsert OPENDATASOURCE('SQLOLEDB','Data Source=远程ip;User ID=sa;Password=密码').库名.dbo.表名(列名1,列名2)SELECT 列名1,列名2FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\test.xls";User ID=Admin;Password=;Extendedproperties=Excel5.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 * fromOPENROWSET('MICROSOFT.JET.OLEDB.4.0','dBase IV;HDR=NO;IMEX=2;DATABASE=C:\','select * from [客户资料4.dbf]') --*/--/* dBase III文件select * fromOPENROWSET('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 intDECLARE @doc varchar(1000)--sample XML documentSET @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位分开。
SQL
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 properti es=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=;Exten ded properties=Excel 5.0')...xactions-------------------------------------------------------------------------------------------------2、将Excel的数据导入SQL server :-- ======================================================SELECT * into newtableFROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\book1.xls";User ID=Admin;Password=;Extended proper ties=Excel 5.0')...[Sheet1$]实例:SELECT * into newtableFROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Exten ded 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:\te mp1.xls -c -q -S"pmserver" -U"sa" -P"sa"'EXEC master..xp_cmdshell 'bcp "SELECT au_fname, au_lname FROM pubs..a uthors ORDER BY au_lname" queryout C:\ authors.xls -c -Sservername -U sa -Ppassword'在VB6中应用ADO导出EXCEL文件代码:Dim cn As New ADODB.Connectioncn.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 propertie s=Excel 5.0')...table1 (A1,A2,A3) values (1,2,3)T-SQL代码:INSERT INTOOPENDATASOURCE('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电子表格软件中的数据进行转换,为我们提供了极大方便!EXEC master..xp_cmdshell 'bcp "select OrderID,ShipName, ShipAdd ress, ShipCity, ShipRegion, ShipPostalCode, ShipCountry from Northwin d.dbo.orders" queryout "d:\Oreders.txt" -t"|" -c -q -S"127 .0.0.1" -U"sa" -P""'SELECT *FROM OpenDataSource('Microsoft.Jet.OLEDB.4.0','Data Source="xxxx. xls";Extended Properties="Excel 8.0";IMEX=1;Persist Security Info =False')...[a1$]二、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 properti es=Excel 5.0')...[Sheet1$]下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。
SQLserver数据库导出为Excel数据的方法
SQLserver数据库导出为Excel数据的方法
社保用友R9.7财务软件后台数据库存为SQLserver数据库,首先利用SQLserver还原数据,并将数据转换为EXCEL 格式文件,再利用AO采集数据库的方式采集数据生成帐表。
数据库存中导出的表为:
1、凭证表:GL-pznr
凭证表导出为EXCEL表后,将各月日期字段值进行修改。
如:200701的值替换为:2007-1-31类型的日期值,各月依次类推。
同时将2008年发生的业务记录全部清除。
2、余额表:GL-kmxx
3、科目表:GL-yeb
操作方法:
1、新建一个Excel表。
2、利用SQLserver还原用友数据库并将其导出为Excel数据
表。
第一步:在还原后的数据库中点右键—所有任务—导出数据
第二步:出现“TDS导入/导出”界面选---下一步
第三步:不作修改选---下一步
第四步:1、在“目的”选项中选“Microsoft Excel 97-2000”
2、在“文件名”选项中选新建的Excel文件“07社保财务数据(用友R9.7).xls”
3、选---下一步
第五步:选下一步
第六步:
1、选择----凭证表:GL-pznr 并在目的名中换名为:凭证表
2、选择----凭证表:GL-yeb 并在目的名中换名为:余额表
3、选择----凭证表:GL-kmxx 并在目的名中换名为:科目表
4、选---下一步
、
第七步:选----下一步
第八步:选---完成。
sql导excel语句
sql导excel语句从SQL数据库导出数据到Excel文件,可以使用以下方法:使用SELECT语句导出数据到一个临时表,然后使用BULK INSERT语句将临时表导出到Excel文件。
●创建临时表●CREATE TABLE temp(●id INT,●name VARCHAR(255),●age INT);●将数据导入临时表●INSERT INTO temp(id,name,age)●VALUES(1,John Doe,30),●(2,Jane Doe,25);●将临时表导出到Excel文件●BULK INSERT C:\temp\data.xlsx●FROM tempWITH●FIELDTERMINATOR=,,●ROWTERMINATOR=\n);使用OPENROWSET函数导出数据到Excel文件。
●将数据导出到Excel文件●OPENROWSET(●Microsoft.ACE.OLEDB.12.0,●Excel 12.0;Database=C:\temp\data.xlsx;,●SELECT id,name,age FROM[dbo].[table]);使用BCP工具导出数据到Excel文件。
●bcp[dbo].[table]●OUT C:\temp\data.xlsx●-S[server]●-U[username]●-P[password]●-c以下是BCP工具的参数说明:1.table:要导出的数据表。
2.OUT:指定导出文件的路径和文件名。
3.-S:指定数据库服务器的名称。
4.-U:指定数据库用户名。
5.-P:指定数据库密码。
6.-c:指定使用逗号分隔数据。
sqlserver批量导出表数据的方法
SQL Server批量导出表数据的方法在SQL Server数据库中,有时我们需要将表数据导出为不同的文件格式,如CSV、Excel等。
本文将介绍几种常用的方法,来实现SQL Server批量导出表数据的功能。
1. 使用BCP命令导出数据BCP(Bulk Copy Program)是SQL Server自带的一个命令行工具,可以用来导入导出数据。
下面是使用BCP命令导出表数据的步骤:1.打开命令提示符或Powershell窗口,输入以下命令:bcp [数据库名称].[表名] out [文件路径] -c -T -S [服务器名称]其中,数据库名称是指要导出数据所在的数据库名,表名是指要导出数据的表名,文件路径是指要导出数据的文件路径,服务器名称是指SQL Server实例的名称。
例如,要将数据库AdventureWorks中的表Sales.SalesOrderDetail的数据导出为CSV文件,可以使用以下命令:bcp AdventureWorks.Sales.SalesOrderDetail out "C:\ExportData.csv" -c -T-S localhost2.执行上述命令后,BCP会将表数据导出为指定的文件。
使用BCP命令导出数据的优点是速度快、可批量导出多个表数据,但缺点是需要使用命令行操作,不够直观。
2. 使用SQL Server Management Studio导出数据SQL Server Management Studio(简称SSMS)是SQL Server的可视化管理工具,可以通过图形化界面导出表数据。
以下是使用SSMS导出表数据的步骤:1.打开SSMS,连接到SQL Server实例,展开数据库和表节点,右键点击要导出数据的表,选择“导出数据”选项。
2.在导出数据向导中,选择数据源和目标:–数据源:选择要导出数据的表。
–目标:选择要导出数据的文件格式(如CSV、Excel等)和文件路径。