【SQL语句】 - Ctrl+3 查询表属性的存储过程

/**-- =============================================
Author:		xft
CteateDate:	2013-10-11
Description:查看表的完整字段信息
Remark:
ModifyHistory:修改 添加了字段长度和标识等信息
**/-- =============================================
CREATE PROCEDURE [dbo].[sp_select_talberowName]
(@tablename varchar(max)) 

AS
BEGIN
SET NOCOUNT ON;
--declare @sql varchar(max)
--set @[email protected]
----set @sql = ‘select a.name,b.value
----from sys.syscolumns a left join sys.extended_properties b on a.id=b.major_id AND a.colid = b.minor_id
----Where a.ID=OBJECT_ID(‘‘‘[email protected]+‘‘‘)‘ 

--set @sql=‘select e.name,c.[type],e.value from ((
--select a.name,b.value
--from sys.syscolumns a left join sys.extended_properties b on a.id=b.major_id AND a.colid = b.minor_id
--Where a.ID=OBJECT_ID(‘‘‘[email protected]+‘‘‘)) as e
--left join (
--select sys.columns.name,sys.types.name as [type] from sys.columns,sys.tables,sys.types
--where sys.tables.object_id=sys.columns.object_id and sys.types.user_type_id=sys.columns.user_type_id
--and sys.tables.name=‘‘‘[email protected]+‘‘‘) as c
--on e.name=c.name)‘ 

--print @sql
--exec (@sql)
DECLARE @sql Nvarchar(2000)
SET @sql = ‘SELECT
字段序号=a.column_id,
字段名=a.name,
类型=b.name,
长度=a.max_length,
小数位数=a.scale,
标识=case    when a.is_identity = 1 THEN ‘+‘‘‘‘+‘是‘+‘‘‘‘+‘ else ‘+ ‘‘‘‘+‘‘+‘‘‘‘ +‘ end,
主键=case   when   exists(SELECT   1   FROM   sys.objects   where   type=‘+‘‘‘‘+‘PK‘+‘‘‘‘+‘  and   name   in   (
SELECT   name   FROM   sys.indexes   WHERE   index_id   in(
SELECT   index_id   FROM   sys.index_columns    WHERE   object_id   =   a.object_id   AND   column_id=a.column_id
)))   then   ‘+‘‘‘‘+‘是‘+‘‘‘‘+‘ else ‘+‘‘‘‘+‘‘+‘‘‘‘+‘end,
允许空=case   when   a.is_nullable=1   then  ‘+‘‘‘‘+‘是‘+‘‘‘‘+‘ else ‘+‘‘‘‘+‘‘+‘‘‘‘+‘ end,
默认值=isnull(e.text,‘+‘‘‘‘+‘‘+‘‘‘‘+‘),
字段说明=isnull(g.[value],‘+‘‘‘‘+‘‘+‘‘‘‘+‘)
FROM   sys.columns   a
left   join   sys.types   b   on   a.user_type_id=b.user_type_id
inner   join   sys.tables    d   on   a.object_id=d.object_id
left   join   sys.syscomments   e   on   a.default_object_id=e.id
left   join   sys.extended_properties   g   on   a.object_id=g.major_id   and   a.column_id=g.minor_id
left   join   sys.extended_properties   f   on   d.object_id=f.major_id   and   f.minor_id=0
WHERE d.name=‘+‘‘‘‘[email protected]+‘‘‘‘+‘order   by  d.name,a.column_id‘
EXEC sp_executesql  @sql
END
GO
时间: 2024-12-11 00:41:52

【SQL语句】 - Ctrl+3 查询表属性的存储过程的相关文章

【SQL语句】 - Ctrl+3 查询表属性的存储过程 [sp_select_talberowName]

/**-- ============================================= Author: xftCteateDate: 2013-10-11Description:查看表的完整字段信息Remark:ModifyHistory:修改 添加了字段长度和标识等信息**/-- ============================================= CREATE PROCEDURE [dbo].[sp_select_talberowName] (@tabl

利用SQL语句查找某数据库中所有存储过程包含的内容(转)

Use 数据库DECLARE @ProcName varchar(50)Create Table #tmpName(Content  varchar(2000))Create Table #tmp(ProcName  varchar(2000),Content1 varchar(8000))--定义一个游标DECLARE SearchProc CURSOR FOR--查询数据库中存储过程的名称,尽量去除系统PROC,可以根据crdate时间字段来寻找非系统PROCselect name from

SQL Server中存储过程 比 直接运行SQL语句慢的原因

问题是存储过程的Parameter sniffing 在很多的资料中都描述说SQLSERVER的存储过程较普通的SQL语句有以下优点: 1. 存储过程只在创造时进行编译即可,以后每次执行存储过程都不需再重新编译,而我们通常使用的SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度. 2. 经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用SP来封装数据库操作.当对数据库进行复杂操作时(如对多个表进行 Update,Insert,Query,Delete时),可将此复杂操作用

SQL Server中存储过程比直接运行SQL语句慢的原因

原文:SQL Server中存储过程比直接运行SQL语句慢的原因 在很多的资料中都描述说SQLSERVER的存储过程较普通的SQL语句有以下优点: 1.       存储过程只在创造时进行编译即可,以后每次执行存储过程都不需再重新编译,而我们通常使用的SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度. 2.       经常会遇到复杂的业务逻辑和对数据库的操作,这个时候就会用SP来封装数据库操作.当对数据库进行复杂操作时(如对多个表进行 Update,Insert,Query

PL/SQL 编程(二)游标、存储过程、函数

游标--数据的缓存区 游标:类似集合,可以让用户像操作数组一样操作查询出来的数据集,实质上,它提供了一种从集合性质的结果中提取单条记录的手段. 可以将游标形象的看成一个变动的光标,他实质上是一个指针,在一段Oracle存放数据查询结果集或者数据操作结果集的内存中,这个指针可以指向结果集任何一条记录. 游标分静态游标和REF游标两类,静态游标包含显式游标和隐式游标. 显式游标: 在使用之前必须有明确的游标声明和定义,这样的游标定义会关联数据查询语句,通常会返回一行或多行.打开游标后,用户可以利用游

SQL语句之 知识补充

SQL语句之 知识补充 一.存储过程 运用SQL语句,写出一个像函数的模块,这就是存储过程. 需求: 编写存储过程,查询所有员工 -- 创建存储过程(必须要指定结束符号) -- 定义结束符号 DELIMITER $ CREATE PROCEDURE pro_test() BEGIN SELECT * FROM student; END $ CALL pro_test     -- 调用存储过程 创建存储语句: delimiter 结束符号 create procedure 存储过程名称( 参数列

为什么数据库有时候不能定位阻塞(Blocker)源头的SQL语句

在SQL Server数据库或OACLE数据库当中,通常一个会话持有某个资源的锁,而另一个会话在请求这个资源,就会出现阻塞(blocking).这是DBA经常会遇到的情况.当出现SQL语句的阻塞时,很多人想查看阻塞的源头(哪个SQL语句阻塞了哪个SQL),这样方便直观.简洁明了的定位问题.但是很多时候,很多场景,我们通过SQL语句并不能或者说不容易定位到阻塞者(Blocker)的SQL语句,当然我们可以很容易找到被阻塞的SQL语句,以及它在等待的锁资源.下面我们先分析一下SQL Server数据

SQL语句 & 查询表结构

[group by] 对结果集进行分组,常与汇总函数一起使用. SELECT column,SUM(column) FROM table GROUP BY column HAVING 通常与 GROUP BY 子句同时使用.不使用 GROUP BY 时, HAVING 则与 WHERE 子句功能相似. Company                          Amount W3Schools                         5500 IBM                

存储过程中执行动态Sql语句

存储过程中执行动态Sql语句 MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就是利用sp_executesql,能够重用执行计划,这就大大提供了执行性能,还可以编写更安全的代码.EXEC在某些情况下会更灵活.除非您有令人信服的理由使用EXEC,否侧尽量使用sp_executesql. 1.EXEC的使用 EXEC命令有两种用法,一种是执行一个存储