免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4697 | 回复: 8
打印 上一主题 下一主题

问个问题--能不能在PF中定义一个有默认值的字段 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-10 21:34 |只看该作者 |倒序浏览
5可用积分
最近在做项目时发现以下几个问题:
1.希望在PF中定义有默认值的字段,比如一个字段,程序WRITE或INERT时,如果没有对该字段赋值,则系统自动使用定义的默认值,该默认值要是程序员自己定义的,不能是"" 或者是0这种。比如,如果用户没有输入金钱的币种,则系统自动默认为"RMB".

2.希望在PF中定义时间戳类型的字段,因为没有在DDS中查到时间戳类型,不知道如何实现。
比如:一条记录WRITE进入PF中,则无需对该字段赋值,该字段自动写上记录WRITE时的日期和时间。类型DB2中的时间戳类型。

谢谢!

论坛徽章:
0
2 [报告]
发表于 2008-09-10 21:52 |只看该作者
http://publib.boulder.ibm.com/infocenter/iadthelp/v6r0/index.jsp?topic=/com.ibm.etools.iseries.langref2.doc/rzakbmsttpdft.htm

DDS for physical and logical filesDFT (Default) keyword--physical files onlyUse this field-level keyword to specify a default value for a field. The format of the keyword is: DFT('value' | numeric-value | X'hexadecimal-value' | *NULL)Without this keyword, character and hexadecimal fields default to blanks and numeric fields default to zeros. However, if you specify the ALWNULL keyword for the field, then the character, hexadecimal, and numeric fields default to the null value. The following rules apply to the specified value:
  • If the field being defined is a character field, specify a character constant, hexadecimal value, or *NULL. Specify character strings within apostrophes. If the field is variable length (VARLEN), then the length of the string must be less than or equal to the allocated length. Specify hexadecimal values as an X followed by a combination of the digits 0 through 9 and the letters A through F. Enclose the combination in apostrophes. The number of hexadecimal digits in apostrophes must be exactly twice the specified length of the field. If the field is variable length (VARLEN), then the number of hexadecimal digits in apostrophes must be exactly twice the allocated length.
  • If the field being defined is a hexadecimal field, specify a character constant, hexadecimal value, or *NULL. Note: If a character constant is specified, the hexadecimal representation of the character constant is the default value. Specify character strings within apostrophes. If the field is variable length (VARLEN), then the length of the string must be less than or equal to the allocated length. Specify hexadecimal values as an X followed by a combination of the digits 0 through 9 and the letters A through F. Enclose the combination in apostrophes. The number of hexadecimal digits in apostrophes must be exactly twice the specified length of the field. If the field is variable length (VARLEN), then the number of hexadecimal digits in apostrophes must be exactly twice the allocated length.
  • If you are defining a numeric field, specify a numeric value (digits 0 through 9 specified without apostrophes) or *NULL. For a value other than zero in positions 36 and 37, specify the decimal character with a numeric constant in the appropriate position in the DDS.
  • If you specify *NULL, then you must also specify the ALWNULL keyword on the field.
  • If you do not specify any value (DFT('')), this indicates a default of a 0 length string and is valid only when the field is variable length (the VARLEN keyword must also be specified).
  • If you are defining a date field, specify a valid date in the same format specified on the DATFMT keyword and use the same separator as specified on the DATSEP keyword. For example, DFT('12/15/91') is the default value if *MDY is specified for DATFMT and '/' is specified for DATSEP. If the DFT keyword is not specified, the default value is the current date.
  • If you are defining a time field, specify a valid time in the same format specified on the TIMFMT keyword and use the same separator as specified on the TIMSEP keyword. For example, DFT('11.00.00') is the default value if *ISO is specified for TIMFMT. The default separator for *ISO is a period (.). If the DFT keyword is not specified, the default value is the current time.
  • If you are defining a timestamp field, you must specify the default value in the following format: DFT('YYYY-MM-DD-HH.MM.SS.UUUUUU')If the DFT keyword is not specified, the default value is the current time.
The value specified is assigned to the field in the following cases:
  • When the program does an output operation to a logical file based on this physical file and the record format in the logical file does not name this field.
  • When you use the Initialize Physical File Member (INZPFM) command for a member in this file.
  • When you use the Copy File (CPYF) command with FMTOPT(*MAP) specified and a field in the to-file is not in the from-file.
The specified value is supplied to the program when the program does an input operation to a join logical file and all of the following are true:
  • You specify the JDFTVAL keyword for the join logical file.
  • The file being defined is specified as a secondary file in the join logical file.
  • When the input operation occurs and the link to the secondary file produces no records.
This keyword does not affect the physical file on input operations. Example: The following example shows how to specify the DFT keyword. |...+....1....+....2....+....3....+....4....+....5....+....6....+....7....+....800010A          R RECORD100020A            CHARFLD1      20A         DFT('Sample field')00030A            CHARFLD2       5A         DFT(X'D985955185')00040A            HEXFLD1        3H         DFT('ABC')00050A            HEXFLD2        3H         DFT(X'C1C2C3')00060A            NUMFLD1        5S 0       DFT(99999)00070A            NUMFLD2        5S 2       DFT(999.99)00080A            NUMFLD3        5S 2       DFT(999)00090A            NUMFLD4        5S 2       DFT(*NULL)00100A                                      ALWNULL00110A            NUMFLD5        5S 2       DFT(999.99)00120A                                      ALWNULL00130A            DATFLD1         L         DATFMT(*MDY) DATSEP('-')00140A                                      DFT('12-31-91')00150A            TIMFLD1         T         DFT('11.15.00')     AThe default value for CHARFLD1 is 'Sample field'. The default value for CHARFLD2 is hex D985955185. The default value for HEXFLD1 is C1C2C3 (the hexadecimal representation of the character constant). The default value for HEXFLD2 is C1C2C3. The default value for NUMFLD1 is 99999 (no decimal character is required because the field has zero decimal positions). The default value for NUMFLD2 is 999.99. The default value for NUMFLD3 is 999 (no decimal character is required if you do not need to specify decimal values). The default value for NUMFLD4 is the null value (ALWNULL is a required keyword for the field if DFT(*NULL) is specified). The default value for NUMFLD5 is 999.99; the field also allows the null value. The default value for DATFLD1 is 12-31-91. The default value for TIMFLD1 is 11.15.00 (*ISO format). [ Top of Page | Previous Page | Next Page | Table of Contents | Index ] (C) Copyright IBM Corporation 1992, 2005. All Rights Reserved.

论坛徽章:
0
3 [报告]
发表于 2008-09-10 21:56 |只看该作者
唉,BBS 还是有 BUG 啊,^C、^V 就不能一致。
还是看 IBM 的原文连接吧。

时间戳类型 是 Z, 可用 TIME 赋值。

论坛徽章:
0
4 [报告]
发表于 2008-09-10 22:14 |只看该作者
试试clear recordformat

论坛徽章:
0
5 [报告]
发表于 2008-09-11 12:31 |只看该作者
如果用到rpg程序操作,太简单了。

1)likeDS

2)inz

论坛徽章:
0
6 [报告]
发表于 2008-09-29 23:51 |只看该作者
想问一下,上面介绍的方法是RPGLE的吧,对于RPG3有没有效果?

论坛徽章:
0
7 [报告]
发表于 2008-10-05 16:14 |只看该作者
这个应该是可以的,通过DDS的键字,RPG3中没有查过reference,但是在v5r3中是可以的,另外通过SQL语句
Alter table alter column  set  语句或者通过create table 中的default 可以实现该功能没问题的。

论坛徽章:
0
8 [报告]
发表于 2008-10-20 21:04 |只看该作者

还是未能解决

还是未能解决

论坛徽章:
0
9 [报告]
发表于 2008-10-21 15:40 |只看该作者
DFT(缺省值)——仅用于物理文件
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP