我将字段添加到 Progress databyse 通过
ADD FIELD filedName on TABLEName...
现在我想更改/修改此字段(PRECISION 或 FORMAT 或其他...)
什么语法是正确的?我试过这样:
UPDATE FIELD
MODIFY FIELD
ALTER FIELD
我尝试了 aldo sql notation:alter table
但没有任何效果。
你能帮我修改字段的语法吗?
我将字段添加到 Progress databyse 通过
ADD FIELD filedName on TABLEName...
现在我想更改/修改此字段(PRECISION 或 FORMAT 或其他...)
什么语法是正确的?我试过这样:
UPDATE FIELD
MODIFY FIELD
ALTER FIELD
我尝试了 aldo sql notation:alter table
但没有任何效果。
你能帮我修改字段的语法吗?
汤姆,谢谢你的回答。
我在 Linux 上使用 OpenEdge Release 10.1A02。
我可以制作一个 dump.df 文件,也可以从文件中添加新表(类似 df)。但是为什么我不能修改任何添加的字段?Ofcorse我可以使用“p”编辑器并从菜单工具/数据编辑器/模式手动执行并添加新表,但如果我告诉数据库管理员在每个环境(特别是在生产环境中)手动执行它是有风险的。
如果存在语法: ADD FIELD filedName on TABLEName... 为什么没有 Modify FIELD filedName on TABLEName... ?
巴特克。
如果您使用 4GL 引擎(您使用 _progres 或 prowin32 启动会话),那么您想使用“数据字典”工具来创建 DDL。您运行“dict.p”来访问该工具。即:_progres dbName -p dict.p
这将允许您创建表、定义字段和索引等。如果您想导出定义,您可以使用“admin”子菜单转储“.df”文件。您可以手动编辑输出,但您需要知道自己在做什么。这很明显,但没有记录或支持。
不要以为在 4GL 会话中使用 SQL 会起作用。它不会。4GL 引擎在内部支持非常有限的 sql-89 子集。它主要是作为一种营销策略。在那条路上,只有痛苦和痛苦。不要去那里。如果您使用 _progres 或 prowin32,则您使用的是 4gl 引擎。
如果您在外部使用 SQL92(通过 sqlexp 或其他使用 ODBC 或 JDBC 连接的第三方 SQL 工具),那么普通的 SQL 内容应该可以工作,但您可能需要花一些时间阅读文档以了解 OpenEdge 的不同之处Oracle 或 Microsoft 或您习惯的任何 sql 方言。
以防万一 - 以下是 OE 11.3 中.df文件的一些工作示例(它们可能在其他版本中也有效):
重命名列:
RENAME FIELD "OldName" OF "TableName" TO "NewName"
其他属性:
UPDATE FIELD "FieldName" OF "TableName"
FORMAT "Yes/No"
LABEL "Label"
VALMSG "Validation message..."
当然,必须先关闭数据库(在单用户模式下应用这些更改)。