有两种解决办法

方法一、是我在网上找的:将原来的sysproperties改成sys.extended_properties并且对应关系如下

sys.extended_properties

left join sys.extended_properties g on a.id=g.class and

a.colid=g.minor_id

left join sys.extended_properties f on d.id=f.class and f.minor_id=0

2000的数据库附加不能05的数据库里出了sysproperties不存在

上面就是解决的方法,以后备用。

【sysproperties】表 原来【SQL2000】中的表【sysproperties】在【SQL2005】中已经不存在了,被是表【extended_properties】取代了。  能不出错吗?

微软公司在升级数据库版本的问题,怎么没有考虑到程序员?

微软删除一个sysproperties表,不知道多少个基于【sysproperties】的程序要出问题。

所以基于上面的解决办法,我找到了

第二个方法,相对比较简单

建一个视图:

CREATE VIEW sysproperties

AS

 SELECT class AS id,Minor_id AS sMallid,* from sys.extended_properties

这样以前写的代码 在找不到表的情况下就会用这个视图。

暂时貌似可以解决问题

举一个列子如下:修改后一样可以在2005中运行:

--查询所有用户表所有字段的特征

SELECT D.Name as TableName, A.colorder AS ColOrder, A.name AS Name,  

  COLUMNPROPERTY(A.ID,A.Name, 'IsIdentity') AS IsIdentity,  

  CASE WHEN EXISTS

  (SELECT 1

  FROM dbo.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 1 ELSE 0 END AS 主键,  

  B.name AS 类型,

  A.length AS [长度],

  A.xprec AS [精度],

  A.xscale AS [小数],

  CASE WHEN A.isnullable = 1 THEN 1 ELSE 0 END AS [可为空],  

ISNULL(E.text, ' ') AS [默认值],  

  ISNULL(G.[value], ' ') AS [说明]

FROM dbo.syscolumns A LEFT OUTER JOIN

  dbo.systypes B ON A.xtype = B.xusertype INNER JOIN

  dbo.sysobjects D ON A.id = D.id AND D.xtype = 'U' AND  

  D.name <> 'dtproperties' LEFT OUTER JOIN

  dbo.syscomments E ON A.cdefault = E.id 

  LEFT OUTER JOIN dbo.sysproperties G ON A.id = G.id AND A.colid = G.smallid

--WHERE D.Name='tablename' --如果找指定表,把注释去掉

ORDER BY 1, 2

上面是 在2000中运行的效果,正确,没问题

下面是利用【sys.extended_properties】的效果,用网上找的方法,可行

--查询所有用户表所有字段的特征

SELECT D.Name as TableName, A.colorder AS ColOrder, A.name AS Name,  

  COLUMNPROPERTY(A.ID,A.Name, 'IsIdentity') AS IsIdentity,  

  CASE WHEN EXISTS

  (SELECT 1

  FROM dbo.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 1 ELSE 0 END AS 主键,  

  B.name AS 类型,

  A.length AS [长度],

  A.xprec AS [精度],

  A.xscale AS [小数],

  CASE WHEN A.isnullable = 1 THEN 1 ELSE 0 END AS [可为空],  

ISNULL(E.text, ' ') AS [默认值],  

  ISNULL(G.[value], ' ') AS [说明]

FROM dbo.syscolumns A LEFT OUTER JOIN

  dbo.systypes B ON A.xtype = B.xusertype INNER JOIN

  dbo.sysobjects D ON A.id = D.id AND D.xtype = 'U' AND  

  D.name <> 'dtproperties' LEFT OUTER JOIN

  dbo.syscomments E ON A.cdefault = E.id 

left join sys.extended_properties g 

on a.id=g.class and 

a.colid=g.minor_id

left join sys.extended_properties f on d.id=f.class and f.minor_id=0

WHERE D.Name='tablename' --如果找指定表,把注释去掉

ORDER BY 1, 2

另外我在 sql2005中建立视图 :

CREATE VIEW sysproperties

AS

 SELECT class AS id,Minor_id AS sMallid,* from sys.extended_properties

后再执行第一个不经过修改用【sysproperties】的代码也能正常运行。

SQL2000的系统表sysproperties在SQL2005中 无效的 问题的更多相关文章

  1. sql server 2000系统表sysproperties在SQL 2008中无效的问题

    Sqlserver有一个扩展属性系统表sysproperties,因为只接触过MSSQL2005及以后的版本,在生产库2008版本及联机文档上搜了下都找不到这个系统表,后来发现这个系统表在2005版本 ...

  2. SQLSERVER系统视图 sql server系统表详细说明

    参考 https://www.cnblogs.com/luluping/archive/2012/11/05/2754639.html https://www.cnblogs.com/litubin/ ...

  3. oracle/ms sql 系统表

    sql server系统表详细说明 sysaltfiles 主数据库 保存数据库的文件 syscharsets 主数据库字符集与排序顺序 sysconfigures主数据库 配置选项 syscurco ...

  4. sql server2008系统表详细说明sys.开头的表

    一.库里有多少个表,表名等 select * from INFORMATION_SCHEMA.TABLES 二.查询表.字段.类型.是否主键.长度.小数位.是否允许空.默认值等详细查询 效果: SEL ...

  5. MS SQL SERVER 中的系统表

    MS SQL SERVER 中的系统表 序号 名称 说明 备注 1 syscolumns 每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行.   2 syscomments 包含每 ...

  6. DataBase 之 数据库中的系统表

    名称                       地址                                                        说明 sysaltfiles    ...

  7. Sqlserver 中系统表sysobjects、syscolumns以及函数object_id

    1.sysobjects 系统对象表. 保存当前数据库的对象,如约束.默认值.日志.规则.存储过程等 sysobjects 重要字段解释: sysObjects ( Name sysname, --o ...

  8. SQlServer 从系统表 sysobjects 中获取数据库中所有表或存储过程等对象

    [sysobjects] 一.概述 系统对象表. 保存当前数据库的对象,如约束.默认值.日志.规则.存储过程等,该表中包含该数据库中的表 存储过程 视图等所有对象 在sqlserver2005,sql ...

  9. SQL Server 地理数据库中的系统表

    转自:http://resources.arcgis.com/zh-cn/help/main/10.1/index.html#/na/002q00000080000000/ 地理数据库的系统表可以强制 ...

随机推荐

  1. fortune 计算公式

    fortune 计算PV值. 举例:一笔 120.00的债权; 12天还完,3.15号借款,3.16开始还款.等额本息还款计算出每天还款: 10.22 根据 现值计算公式 PV = CFn/(1+r) ...

  2. tomcat管理员在远程(不同)机器上访问管理页面

    tomcat8.5管理员默认只能在安装tomcat的机器上访问,如果想在其他机器上访问,则需要进行配置修改 添加用户和权限(<tomcat>\conf\tomcat-users.xml): ...

  3. 火狐浏览器flash经常奔溃的

    火狐浏览器flash经常奔溃的 1.首先,在火狐浏览器地址栏在输入:about:config?filter=dom.ipc.plugins.flash.disable-protected-mode,按 ...

  4. WIN下Git GUI 教程

    现在很多都有git来托管项目或者来查找资料,但是看起来操作不是很方便,现在由于win下可以直接使用git gui,让使用git变得方便,当然这只是针对日常简单的使用,如果想详细的使用,可以去参考廖学峰 ...

  5. libvlc_new 调用产生段错误

    在调试程序的时候,碰到一个奇怪的段错误问题.只要链接的时候使用-Wl,-rpath=./vlc/lib就会产生段错误,如果链接的时候使用的是-Wl,-rpath=../../tool/vlc/lib则 ...

  6. [转载]Windows x64下配置ffmpeg的方法

    ffmpeg简介 FFmpeg 是一款跨平台的,对视频.音频进行录制.转换.播放的命令行形式软件,它使用的是 libavcodec 编解码器.FFmpeg 官方网站是 http://ffmpeg.or ...

  7. Eclipse和MyEclipse使用技巧--Eclipse中使用Git-让版本管理更简单

    详细步骤: 第一部分  GIT介绍 (1)GIT往世今生 2005年开发Samba的Andrew试图破解BitKeeper(一款商业的版本控制系统)的协议(这么干的其实也不只他一个),被BitMove ...

  8. SVM 推到期间 遇到的 表背景知识 (间隔最大化)

    背景,在看原理的时候,发现很多地方一知半解的,补充如下. 其他补充: 注:以下的默认为2分类 1.SVM原理: (1)输入空间到特征空间得映射 所谓输入空间即是输入样本集合,有部分情况输入空间与特征空 ...

  9. Red Hat7.2 上安装 MySQL5.5.58

    1.首先查看linux版本:cat /etc/redhat-release Red Hat Enterprise Linux Server release 7.2 (Maipo) 2.Linux查看版 ...

  10. 使用maven编译Java项目

    摘要: 综述 本文演示了用Maven编译Java项目 需要 时间:15分钟 文本编辑器或者IDE JDK 6 或者更高版本 创建项目 本例主要为了展示Maven,所以Java的项目力求简单. 创建项目 ...