zoukankan
html css js c++ java
导出表数据脚本的存储过程 [转自CSDN]
生成表数据脚本的存储过程
CREATE
PROCEDURE
dbo.OutputData
@tablename
sysname
AS
declare
@column
varchar
(
1000
)
declare
@columndata
varchar
(
1000
)
declare
@sql
varchar
(
4000
)
declare
@xtype
tinyint
declare
@name
sysname
declare
@objectId
int
declare
@objectname
sysname
declare
@ident
int
set
nocount
on
set
@objectId
=
object_id
(
@tablename
)
if
@objectId
is
null
--
判断对象是否存在
begin
print
@tablename
+
'
对象不存在
'
return
end
set
@objectname
=
rtrim
(
object_name
(
@objectId
))
if
@objectname
is
null
or
charindex
(
@objectname
,
@tablename
)
=
0
begin
print
@tablename
+
'
对象不在当前数据库中
'
return
end
if
OBJECTPROPERTY
(
@objectId
,
'
IsTable
'
)
<
>
1
--
判断对象是否是表
begin
print
@tablename
+
'
对象不是表
'
return
end
select
@ident
=
status
&
0x80
from
syscolumns
where
id
=
@objectid
and
status
&
0x80
=
0x80
if
@ident
is
not
null
print
'
SET IDENTITY_INSERT
'
+
@TableName
+
'
ON
'
--
定义游标,循环取数据并生成Insert语句
declare
syscolumns_cursor
cursor
for
select
c.name,c.xtype
from
syscolumns c
where
c.id
=
@objectid
order
by
c.colid
--
打开游标
open
syscolumns_cursor
set
@column
=
''
set
@columndata
=
''
fetch
next
from
syscolumns_cursor
into
@name
,
@xtype
while
@@fetch_status
<>
-
1
begin
if
@@fetch_status
<>
-
2
begin
if
@xtype
not
in
(
189
,
34
,
35
,
99
,
98
)
--
timestamp不需处理,image,text,ntext,sql_variant 暂时不处理
begin
set
@column
=
@column
+
case
when
len
(
@column
)
=
0
then
''
else
'
,
'
end
+
@name
set
@columndata
=
@columndata
+
case
when
len
(
@columndata
)
=
0
then
''
else
'
,
''
,
''
,
'
end
+
case
when
@xtype
in
(
167
,
175
)
then
'''''''''
+
'
+
@name
+
'
+
'''''''''
--
varchar,char
when
@xtype
in
(
231
,
239
)
then
'''
N
''''''
+
'
+
@name
+
'
+
'''''''''
--
nvarchar,nchar
when
@xtype
=
61
then
'''''''''
+convert(char(23),
'
+
@name
+
'
,121)+
'''''''''
--
datetime
when
@xtype
=
58
then
'''''''''
+convert(char(16),
'
+
@name
+
'
,120)+
'''''''''
--
smalldatetime
when
@xtype
=
36
then
'''''''''
+convert(char(36),
'
+
@name
+
'
)+
'''''''''
--
uniqueidentifier
else
@name
end
end
end
fetch
next
from
syscolumns_cursor
into
@name
,
@xtype
end
close
syscolumns_cursor
deallocate
syscolumns_cursor
set
@sql
=
'
set nocount on select
''
insert
'
+
@tablename
+
'
(
'
+
@column
+
'
) values(
''
as
''
--
''
,
'
+
@columndata
+
'
,
''
)
''
from
'
+
@tablename
print
'
--
'
+
@sql
exec
(
@sql
)
if
@ident
is
not
null
print
'
SET IDENTITY_INSERT
'
+
@TableName
+
'
OFF
'
exec
OutputData2
'
表名
'
查看全文
相关阅读:
unix改变shell显示颜色
实习三个月的地一个完整项目总结
Can't open named pipe to host: . pipe: MySQL
OpenGL 与 GLSL 版本号
牛腩新闻系统(二)——原型图、数据库文档
【Android开发学习之路】
JAVA多线程的问题以及处理【转】
Class.forName的作用以及为什么要用它【转】
java的集合类【转】
JAVA的包装类 【转】
原文地址:https://www.cnblogs.com/LCX/p/1105767.html
最新文章
从零单排入门机器学习:线性回归(linear regression)实践篇
uva是崩了 吗,还是我太年轻?
android AChartEnginee解说之源代码框架解读
驱动开发之 设备读写方式:缓冲区方式
Android中关于JNI 的学习(一)对于JNIEnv的一些认识
hive正則表達式
BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第12章节--SP 2013中远程Event Receivers 总结
OpenCV打开摄像头失败
利用scrapy抓取网易新闻并将其存储在mongoDB
C++设计模式之状态模式(二)
热门文章
[ExtJS5学习笔记]第八节 Extjs5的Ext.toolbar.Toolbar工具条组件及其应用
[leetcode 240]Search a 2D Matrix II
How to fix yum errors on CentOS, RHEL or Fedora
JAVA基础实例(一)
java基础开发—jstl标签库
【NoSql】Redis实践篇-简单demo实现(一)
设计模式------简单工厂模式
STL之set具体解释(二)
MySQL提示Access denied for user ''@'localhost'”的解决
自己定义UITextField
Copyright © 2011-2022 走看看