进度 - 修改FIELD的语法

问题描述 投票:0回答:3

我添加了字段到Progress databyse

ADD FIELD filedName on TABLEName...

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

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

  • UPDATE FIELD
  • MODIFY FIELD
  • ALTER FIELD

我试过aldo sql表示法:alter table但没有任何作用。

你可以用语法修改字段来帮助我吗?

database openedge progress-db
3个回答
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方言。


0
投票

汤姆,谢谢你的回答。

我在Linux上使用OpenEdge Release 10.1A02。

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

如果存在语法:TABLEName上的ADD FIELD filedName ...为什么在TABLEName上没有修改FIELD filedName ...?

鲍尔泰克。


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..."

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

© www.soinside.com 2019 - 2024. All rights reserved.