查询表结构信息

利用 Sql 中查看表结构信息。
作者:admin
 

--查询表结构信息
--邹老大的

(1)
SELECT
表名=case when a.colorder=1 then d.name else '' end,
表说明=case when a.colorder=1 then isnull(f.value,'') else '' end,
字段序号=a.colorder,
字段名=a.name,
标识=case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end,
主键=case when exists(SELECT 1 FROM sysobjects where xtype='PK' and parent_obj=a.id and name in (
SELECT name FROM sysindexes WHERE indid in(
SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid
))) then '√' else '' end,
类型=b.name,
占用字节数=a.length,
长度=COLUMNPROPERTY(a.id,a.name,'PRECISION'),
小数位数=isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0),
允许空=case when a.isnullable=1 then '√'else '' end,
默认值=isnull(e.text,''),
字段说明=isnull(g.[value],'')
FROM syscolumns a
left join systypes b on a.xusertype=b.xusertype
inner join sysobjects d on a.id=d.id  and d.xtype='U' and  d.name<>'dtproperties'
left join syscomments e on a.cdefault=e.id
left join sysproperties g on a.id=g.id and a.colid=g.smallid 
left join sysproperties f on d.id=f.id and f.smallid=0
--where d.name='要查询的表'    --如果只查询指定表,加上此条件
order by a.id,a.colorder

(2)

SQL2000系统表的应用
--1:获取当前数据库中的所有用户表

select Name from sysobjects where xtype='u' and status>=0

--2:获取某一个表的所有字段

select name from syscolumns where id=object_id('表名')

--3:查看与某一个表相关的视图、存储过程、函数

select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'

--4:查看当前数据库中所有存储过程

select name as 存储过程名称 from sysobjects where xtype='P'

--5:查询用户创建的所有数据库

select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa')

或者

select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01

--6:查询某一个表的字段和数据类型

select column_name,data_type from information_schema.columns
where table_name = '表名'

--7:取得表字段的描述
select name,
(select value from sysproperties where id = syscolumns.id and smallid=syscolumns.colid) as 描述
from syscolumns where id=object_id('表名')
Sql Server 常用函数
作者:super
 

1.统计函数 avg, count, max, min, sum 

多数聚合不统计值为null的行。可以与distinct一起使用去掉重复的行。可以与group by 来分组 

2. 数学函数 

SQRT 
ceiling(n) 返回大于或者等于n的最小整数 
floor(n), 返回小于或者是等于n的最大整数 
round(m,n), 四舍五入,n是保留小数的位数 
abs(n) 
sign(n), 当n>0, 返回1,n=0,返回0,n<0, 返回-1 
PI(), 3.1415.... 
rand(),rand(n), 返回0-1之间的一个随机数 

3.字符串函数 

ascii(), 将字符转换为ASCII码, ASCII('abc') = 97 
char(), ASCII 码 转换为 字符 
lower(),upper() 
str(a,b,c)转换数字为字符串。 a,是要转换的字符串。b是转换以后的长度,c是小数位数。str(123.456,8,2) = 123.46 
ltrim(), rtrim() 去空格 
left(n), right(n), substring(str, start,length) 截取字符串 
charindex(子串,母串),查找是否包含。 返回第一次出现的位置,没有返回0 
patindex('%pattern%', expression) 功能同上,可是使用通配符 
replicate('char', rep_time), 重复字符串 
reverse(char),颠倒字符串 
replace(str, strold, strnew) 替换字符串 
space(n), 产生n个空行 
stuff(), SELECT STUFF('abcdef', 2, 3, 'ijklmn') ='aijklmnef', 2是开始位置,3是要从原来串中删除的字符长度,ijlmn是要插入的字符串。 
ISNULL(字段,0)没有记录用 ISNULL(SUM(字段),0)

4.类型转换函数 

cast, cast( expression as data_type), Example: 
SELECT SUBSTRING(title, 1, 30) AS Title, ytd_sales FROM titles WHERE CAST(ytd_sales AS char(20)) LIKE '3%' 
convert(data_type, expression) 

5.日期函数 

day(), month(), year() 
dateadd(datepart, number, date), datapart指定对那一部分加,number知道加多少,date指定在谁的基础上加。datepart的取值包括,year,quarter,month,dayofyear,day,week,hour,minute,second,比如明天dateadd(day,1, getdate()) 
datediff(datepart,date1,date2). datapart和上面一样。整个函数结果是date2 - date1 
datename(datepart, date) 取那一部分,返回字符串。 
datepart(datepart, date) 取一部分,返回整数。 
getdate()当前时间 

6.系统函数 

col_length('tablename','colname') 
col_name, SELECT COL_NAME(OBJECT_ID('Employees'), 1) = EmployeeID 
datalength, example: datalenght('abc') =3, datalength(pub_name) --列名 
db_id

posted on 2006-04-27 13:03  Sanle  阅读(318)  评论(0编辑  收藏  举报

导航