JAVA—咖啡馆

——欢迎访问rogerfan的博客,常来《JAVA——咖啡馆》坐坐,喝杯浓香的咖啡,彼此探讨一下JAVA技术,交流工作经验,分享JAVA带来的快乐!本网站部分转载文章,如果有版权问题请与我联系。

BlogJava 首页 新随笔 联系 聚合 管理
  447 Posts :: 145 Stories :: 368 Comments :: 0 Trackbacks

最近做一个项目,客户希望可以自己选择想要查看的列表,这样就不好办了,选择列表的名字他们也想自定义,没办法这就需要查看数据表中字段,中文说明,默认标志了。在网上查了部分资料但是发现粘上去的代码都存在问题,无奈只好自己修改了一下,代码如下:

如下代码能正常运行,都是网上查找资料最后拼凑总结出来的。条件就自己加吧。网上好像也有不少类型的东西,这里留着以备不时只需!

SELECT (CASE
         
WHEN a.colorder = 1 THEN
          d.NAME
         
ELSE
          
''
       
END) N'表名',
       a.colorder N
'字段序号',
       a.NAME N
'字段名',
       (
CASE
         
WHEN columnproperty(a.id, a.NAME, 'IsIdentity'= 1 THEN
          
''
         
ELSE
          
''
       
END) N'标识',
       (
CASE
         
WHEN (SELECT COUNT(*)
                 
FROM sysobjects
                
WHERE (NAME IN
                      (
SELECT NAME
                          
FROM sysindexes
                         
WHERE (id = a.id)
                           
AND (indid IN
                               (
SELECT indid
                                   
FROM sysindexkeys
                                  
WHERE (id = a.id)
                                    
AND (colid IN
                                        (
SELECT colid
                                            
FROM syscolumns
                                           
WHERE (id = a.id)
                                             
AND (NAME = a.NAME)))))))
                  
AND (xtype = 'PK')) > 0 THEN
          
''
         
ELSE
          
''
       
END) N'主键',
       b.NAME N
'类型',
       a.length N
'占用字节数',
       
columnproperty(a.id, a.NAME, 'PRECISION'AS N'长度',
       
isnull(columnproperty(a.id, a.NAME, 'Scale'), 0AS N'小数位数',
       (
CASE
         
WHEN a.isnullable = 1 THEN
          
''
         
ELSE
          
''
       
END) N'允许空',
       
isnull(e.text'') N'默认值',
       
isnull(g. VALUE, ''AS N'字段说明'
--into ##tx
  FROM syscolumns a
  
LEFT JOIN systypes b ON a.xtype = 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 sys.extended_properties g ON a.id = g.major_id
                                     
AND a.colid = g.minor_id
 
ORDER BY object_name(a.id), a.colorder

sysproperties表的详解: 

1、表名:sqlserver的注释表,每个数据库都有,包括表和字段的注释,表或者列的注释都会存储,没有注释不存储。 
2、字段: 
  id:表的ID或者是列的ID 
  smallid:列的顺序,排序用 
  type:3 表,4字段,可能还有约束什么的,还没有测试出 
  name:统一的MS_Description 
  value:描述

 

如需修改(转载部分)

如果需要更新 此表的 内容 需要 开启 [允许对系统目录直接进行修改] ,否则 改不了 系统表

如果 不开启 此 功能  ,那么也可以 使用 存储过程[sp_addextendedproperty] 来 添加\更新\删除 表和字段的描述 用法如下


 

 --创建表
Create Table 表(a1 varchar(10),a2 char(2))

--为表 添加 描述信息 : 第二个参数为 [描述] 第六个参数为 [表名]
EXECUTE sp_addextendedproperty N'MS_Description', '人员信息表', N'user', N'dbo', N'table', N'表', NULL, NULL

--为表 更新 描述信息 : 第二个参数为 [描述]  第六个参数为 [表名]
EXECUTE sp_updateextendedproperty 'MS_Description',N'adsfasfdas', N'user', N'dbo', N'table', N'表', NULL, NULL

--为表 删除 描述信息 : 第五个参数为 [表名]
EXEC sp_dropextendedproperty 'MS_Description',N'user', N'dbo', N'table', N'表', NULL, NULL

 

--字段的 添加 更新 删除 方法 
--为 字段a1 添加 描述信息: 第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] 
EXECUTE sp_addextendedproperty N'MS_Description', '姓名', N'user', N'dbo', N'table', N'表', N'column', N'a1'

--更新 字段 a1 的描述属性:第二个参数为 [描述] 第六个参数为 [表名] 第八个参数为 [字段名称] 
EXEC sp_updateextendedproperty 'MS_Description','字段1dd','user',dbo,'table','表','column',N'a1'

--删除 字段 a1 的描述属性:第五个参数为 [表名] 第七个参数为 [字段名称] 
EXEC sp_dropextendedproperty 'MS_Description','user',dbo,'table','表','column','a1'

--删除测试
Drop Table 表

posted on 2013-03-31 04:59 rogerfan 阅读(844) 评论(0)  编辑  收藏 所属分类: 【数据库】

只有注册用户登录后才能发表评论。


网站导航: