如何用SQL语句取得数据库sql2005中的所有数据表中每一个字段的描述信息呢?(高手请进入!!)

zhbzspqxl2 2006-03-15 10:08:51


方法一:
SELECT

表名=case when a.colorder=1 then d.name 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 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.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 sysproperties g on a.id=g.id and a.colid=g.smallid

where g.name='MS_Description'

order by a.id,a.colorder

//////////////

网上查的,上面的程序在SQL2005下不能执行,主要是找不到sysproperties
以下为提示信息:
Msg 208, Level 16, State 1, Line 1
Invalid object name 'dbo.sysproperties'.


方法二:
在VS2005中用类示GetSchemaTable(),有很多表的结构信息,却没有字段的描述信息Description,
可我要的就是字段的描述信息啊!!

难到SQL2005就找不出数据字典中的字段描述吗?

...全文
304 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
netcoder 2006-03-23
  • 打赏
  • 举报
回复
象sysproperties这样无正式文档记载的系统表还是不要用的好,
很有可能在SQL Server的新版本或者补丁正不在支持,在SQL 2005中使用sys.extended_properties

--修改后如下

SELECT
表名=case when a.colorder=1 then d.name 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 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.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 d.id=g.major_id and a.colid=g.minor_id
--取消下面的注释则只返回有描述的字段
--where g.name='MS_Description'

order by a.id,a.colorder
zhbzspqxl2 2006-03-15
  • 打赏
  • 举报
回复
up
内容概要:本文围绕配电网两阶段鲁棒故障恢复问题展开研究,基于Matlab代码实现了对IEEE顶刊论文的复现,系统构建了包含两阶段鲁棒优化模型与确定性模型在内的完整故障恢复框架。研究聚焦于提升故障后配电网的供电可靠性与恢复能力,通过第一阶段的网络重构与资源预调度,以及第二阶段对不确定性因素(如负荷波动、分布式电源出力间歇性)的动态响应,实现供电快速恢复与负荷损失最小化。采用鲁棒优化方法有效处理系统不确定性,保障运行方案的安全性与可行性,并提供完整的仿真代码与实验结果,验证了所提模型在复杂场景下的有效性与先进性。; 适合人群:具备电力系统分析基础、熟悉Matlab编程环境,从事配电网优化运行、故障恢复策略、鲁棒优化建模等方向的研究生、科研人员及电力系统工程技术人员。; 使用场景及目标:① 掌握配电网故障恢复两阶段鲁棒优化的建模思想与数学表达;② 复现并验证高水平期刊论文的优化算法,支撑科研仿真与方法对比;③ 应用于实际配电系统应急恢复方案设计,提升面对突发故障的自愈能力与运行韧性。; 阅读建议:建议结合Matlab代码逐模块调试运行,重点关注YALMIP工具箱调用、两阶段优化问题的建模结构与列与约束生成(C&CG)算法的实现流程,深入理解鲁棒对等转化机制,并可进一步拓展至主动配电网、高比例可再生能源接入等复杂应用场景的适应性研究。
源码下载地址: https://pan.quark.cn/s/1e5deb07fd7f **RADTools 2安装文件说明**RADTools 2是一款为游戏开发者和爱好者量身打造的软件,其核心功能在于处理游戏环境的BAK文件。BAK文件是众多游戏采用的一种数据存储方案,通常承载着游戏的各种元素,包括图像、声音、动画以及剧本等资料。借助RADTools 2,用户可以轻松地解包这些BAK文件,进而对文件内的内容进行查看、编辑或导出,这一过程对于游戏调试、MOD开发或深入探究游戏构造具有显著的辅助作用。**BAK文件解包过程**BAK文件采用压缩格式,旨在节省存储空间并确保游戏资源不被随意篡改。RADTools 2内置的解包机制能够将BAK文件转换回其初始的数据形态,使用户得以洞察每个资源的详细构成。解包操作通常自动化完成,用户只需选定相应的BAK文件,再借助RADTools 2的图形界面进行操作,即可实现解包,无需具备专业的编程知识。**封包视频预览功能**RADTools 2不仅具备基础的解包能力,还支持对封包视频的预览。部分游戏为了优化存储效率,会将视频文件整合在BAK文件内。借助这一工具,用户可以直接预览这些内置的视频内容,无需事先进行解包。这一特性对于游戏开发者而言,意味着可以在开发环境即时评估视频素材的表现。**简易安装与操作**"RADTools 2原生安装包"代表了该软件提供了高效的安装体验。用户只需获取并启动`RADTools_2.exe`,遵循安装向导的指引操作,即可在个人计算机上顺利完成RADTools 2的部署。安装后,用户可以直接通过软件界面启动RADTools 2,无需进行额外的系统设置,充分展现了其便捷性和用户友好设计。**可能...

22,296

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧