
- 帖子
- 7
- 积分
- 10
- 威望
- 12
- 金钱
- 11
- 在线时间
- 0 小时
|
哎,LZ为什么就不去GOOGLE搜搜呢
你们老师也是误导人
MSSQL功能这么强,不至于连这点事都解决不了
说2个解决方法,都是超级简单
首先如果你在企业管理器里操作的话,你在你要导入数据的数据库上单击右键-任务-导入数据
数据源那里选择文本文件,分隔符选择空格,NEXT,NEXT,NEXT。。。OK
第二如果你想用SQL语句,参考这篇文章
<<单表导入/导出文本文件>>
/*--实现数据导入/导出的存储过程
可以实现导入/导出 指定表 到文本文件
支持自定义行/列分隔符
--邹建 2003.07--*/
/*--调用示例
导出调用示例
--导出指定表,这里指定导出表:地区资料
exec file2table @#zj@#,@#@#,@#@#,@#c:\zj.txt@#,@#xzkh_new..地区资料@#,@rowsplit=@#,@#
导入调用示例
--导入指定表,这里指定导入表:地区资料
exec file2table @#zj@#,@#@#,@#@#,@#c:\zj.txt@#,@#xzkh_sa..地区资料@#,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) --密码
,@filename varchar(1000) --目录名+文件名
,@tbname varchar(500)=@#@# --数据库..表名
,@isout bit=1 --1为导出(默认),0为导入
,@fdsplit varchar(10)=@#\t@# --字段分隔符,默认为制表符
,@rowsplit varchar(10)=@#\n@# --记录分隔符,默认为回车符
as
declare @sql varchar(8000)
set @sql=@#bcp "@#+@tbname
+case when @isout=1 then @#" out@# else @#" in@# end
+@# "@#+@filename+@#" /c@# +@# /S"@#+@servername
+case when isnull(@username,@#@#)=@#@# then @#@#
else @#" /U"@#+@username end
+@#" /P"@#+isnull(@password,@#@#)+@#"@#
+@# /t"@#+@fdsplit+@#"@#
+@# /r"@#+@rowsplit+@#"@#
exec master..xp_cmdshell @sql
go
OK,不要光想着select insert,随便搜搜就有解决办法了: |www.hack521.cn
帖子207 精华1 积分3652 阅读权限150 在线时间464 小时 注册时间2007-4-12 最后登录2008-7-22 查看个人网站
查看详细资料TOP
伤心的鱼 
运维管理组
    |
|