1

我将字段添加到 Progress databyse 通过

ADD FIELD filedName on TABLEName...

现在我想更改/修改此字段(PRECISION 或 FORMAT 或其他...)

什么语法是正确的?我试过这样:

  • UPDATE FIELD
  • MODIFY FIELD
  • ALTER FIELD

我尝试了 aldo sql notation:alter table 但没有任何效果。

你能帮我修改字段的语法吗?

4

3 回答 3

1

汤姆,谢谢你的回答。

我在 Linux 上使用 OpenEdge Release 10.1A02。

我可以制作一个 dump.df 文件,也可以从文件中添加新表(类似 df)。但是为什么我不能修改任何添加的字段?Ofcorse我可以使用“p”编辑器并从菜单工具/数据编辑器/模式手动执行并添加新表,但如果我告诉数据库管理员在每个环境(特别是在生产环境中)手动执行它是有风险的。

如果存在语法: ADD FIELD filedName on TABLEName... 为什么没有 Modify FIELD filedName on TABLEName... ?

巴特克。

于 2013-10-30T10:54:05.543 回答
1

如果您使用 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 方言。

于 2013-10-29T13:23:36.607 回答
0

以防万一 - 以下是 OE 11.3 中.df文件的一些工作示例(它们可能在其他版本中也有效):

  • 重命名列:

    RENAME FIELD "OldName" OF "TableName" TO "NewName"

  • 其他属性:

    UPDATE FIELD "FieldName" OF "TableName"

    FORMAT "Yes/No"

    LABEL "Label"

    VALMSG "Validation message..."

当然,必须先关闭数据库(在单用户模式下应用这些更改)。

于 2019-04-16T07:04:02.987 回答