日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

解决PowerDesigner 16 Generate Datebase For Sql2005/2008 对象名sysproperties无效的问题

發布時間:2025/3/15 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 解决PowerDesigner 16 Generate Datebase For Sql2005/2008 对象名sysproperties无效的问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在PowerDesigner 16 中生成的sql語句,在執行的時候報錯:對象名sysproperties 無效的錯誤;造成此問題的原因是由于Sql 2005、2008 刪除了系統表 sysproperties 而改用 sys.extended_properties 表所致 , 以下是通過創建sysproperties視圖,以及修改powerdesigner sql語句生成模板后,

再生成數據庫SQL腳本執行,共分為三部:


第一步:在Sql 2005/2008 Exec the Sql 創建View 'sysproperties'

if exists (select 1 from sysobjects where name = 'sysproperties'and xtype = 'V') beginDROP VIEW sysproperties endGOCREATE VIEW syspropertiesASSELECT A.name As TableName,A.id As TableID,B.Name As ColName,B.colid As ColID,B.xtype As ColType,C.name As PropName,C.Value As PropValueFROM sysobjects As A INNER JOIN syscolumns As B ON A.id = B.idINNER JOIN sys.extended_properties As C ON C.major_id = A.id AND ( minor_id = B.colid)

第二 步: 修改Table TableComment模板 路徑是 Database -> Edit Current DBMS 窗體 General 選項卡 下 Script -> Objects -> Table -> TableComment

按 Ctrl+C 復制代碼 [if exists (select 1?
from sys.extended_properties?
where major_id = object_id('[%QUALIFIER%]%TABLE%')?
and minor_id = 0 and name = 'MS_Description')?
begin?
[%OWNER%?[.O:[execute ][exec ]]sp_dropextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]'user', [%R%?[N]]%.q:OWNER%, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%?
:declare @CurrentUser sysname?
select @CurrentUser = user_name()?
[.O:[execute ][exec ]]sp_dropextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]'user', [%R%?[N]]@CurrentUser, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%?
]?
end?


][%OWNER%?[.O:[execute ][exec ]]sp_addextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]%.q:COMMENT%,?
[%R%?[N]]'user', [%R%?[N]]%.q:OWNER%, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%?
:select @CurrentUser = user_name()?
[.O:[execute ][exec ]]sp_addextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]%.q:COMMENT%,?
[%R%?[N]]'user', [%R%?[N]]@CurrentUser, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%?
] 第三步:修改Column ColumnComment模板 路徑是 Database -> Edit Current DBMS 窗體 General 選項卡 下 Script -> Objects -> Column -> ColumnComment 按 Ctrl+C 復制代碼 [if exists (select 1
from sysproperties
where TableID = object_id('[%QUALIFIER%]%TABLE%')
and ColName = %.q:COLUMN% AND PropName='MS_Description')
begin
[%OWNER%?[.O:[execute ][exec ]]sp_dropextendedproperty [%R%?[N]]'MS_Description',
[%R%?[N]]'user', [%R%?[N]]%.q:OWNER%, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%, [%R%?[N]]'column', [%R%?[N]]%.q:COLUMN%
:declare @CurrentUser sysname
select @CurrentUser = user_name()
[.O:[execute ][exec ]]sp_dropextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]'user', [%R%?[N]]@CurrentUser, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%, [%R%?[N]]'column', [%R%?[N]]%.q:COLUMN%
]


end


][%OWNER%?[.O:[execute ][exec ]]sp_addextendedproperty [%R%?[N]]'MS_Description',
[%R%?[N]]%.q:COMMENT%,
[%R%?[N]]'user', [%R%?[N]]%.q:OWNER%, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%, [%R%?[N]]'column', [%R%?[N]]%.q:COLUMN%
:select @CurrentUser = user_name()
[.O:[execute ][exec ]]sp_addextendedproperty [%R%?[N]]'MS_Description',?
[%R%?[N]]%.q:COMMENT%,
[%R%?[N]]'user', [%R%?[N]]@CurrentUser, [%R%?[N]]'table', [%R%?[N]]%.q:TABLE%, [%R%?[N]]'column', [%R%?[N]]%.q:COLUMN%
]

修改之后 使用Generate Database 生成的SQL便可在SQL 2005/2008下執行 不在報找不到sysproperties 的錯誤。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的解决PowerDesigner 16 Generate Datebase For Sql2005/2008 对象名sysproperties无效的问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。