介绍一下数据类配置,该数据类配置主要用于需要将数据库 mysql 数据转换成 java 对象,再转换为 as3 对象的数据类
配置文件为 xml 格式。
<objects> <object name="TUserVO" tableName="v_user" note="注释" author="idoublewei"> <field name="id" type="integer" restrict="primary key" value="0" note="标识"/> <field name="name" type="string|32" restrict="not null" value="" note="昵称"/> </object> </objects>
配置中只能有一个根节点 objects,每个子节点 object 代表一个数据类,object 的每个子节点 field 代表该数据类的一个属性
object :
---name 表示数据类名,必须指定
---tableName 表示生成的 mysql 对应表名,如果不指定该属性,则会使用 name 作为表名
---note 数据类注释,可以不指定
---author 数据类创建者,可以不指定
field :
---name 表示数据类的属性名,必须指定
---type 表示数据类属性类型,必须指定(区分大小写)
------string 表示字符串,后可接符号 "|" + 数字,表示字符串长度,例如 - string|32,接符号"|text",表示数据库使用TEXT类型
------integer 表示整数
------unsigned 表示非负整数
------decimal 表示小数
------bool 表示布尔值
------date 表示日期
---restrict 表示数据库字段约束,会原样输出,可以不指定
---value 表示数据类属性默认值(数据库默认为 null),可以不指定
------如果 type 为 bool,只能取值:true, false
------如果 type 为 date,可以取值:new - 新建对象,ms - 日期毫秒数,后接符号 "|" + 数字,例如 - ms|428,format - 日期字符串,后接符号 "|" + 日期格式字符,例如 - format|14-04-16 20:15:36 637
---note 数据类属性注释,可以不指定
需要注意的是,在指定数据类属性类型时,如果指定的类型不在支持类型列表中,则会原样输出,比如配置属性为
<field name="attr" type="com.vo.MyClass" value="null"/>
则输出为
---as3 : var attr:com.vo.MyClass = null;
---java : com.vo.MyClass attr = null;
---mysql : attr com.vo.MyClass null,
因为数据库完全不认识 com.vo.MyClass 类型,所以不建议在该处这样配置。在下一篇的介绍(只存在于 as3 和 java 数据类同步)中,是可以这样配置的。