admin 管理员组文章数量: 1086019
2024年6月2日发(作者:哦玛瑞亚玛瑞亚玛瑞亚是什么歌)
专栏首页 → Java编程 → Java综合 → 专栏: nutz 专栏 → 章节:数据持久
化 --
实体注释(Entity
Annotation)一览表
阅读:618次 评论:10条 更新时间:2009-05-05
实体注释(Entity Annotation)一览表
Annotation 描述
@Table
类对象声明,表示一个 POJO 为一个可接受的对象,可以
对应数据表或者视图 @Table("表或者视图名") 如果不声明值,那
么 将把该对象的
getClass().getSimpleName().toLowerCase() 作为数据表的名称
声明一个实体的时候,有些时候你需要将它存在某一个Table中,
但是你却希望从一个View中获取。 这么做通常是希望View可以帮
你做一些数据的统计方面的工作。 支持你为一个实体 声
明一个 @Table 的同时也声明一个 @View,对于一个对象,
的“增,删,改”操作将针对Table,而“查”操作将针对
View。 实际上,如果你没有声明 @View, 那么你声明的@Table 将
作为@View 的默认设置。
@View
字段声明,表示当前字段可以被映射到数据库中, @Column("字段
名") 可以指定到特定的数据库字段, 如果不指定,那么将采用
@Column
e()作为名字,大小写是否敏感将依各个不同的数据库
来定。
字段声明,告诉 本字段将作为一个 ID来使用。默认的,
将在每次向数据库中插入一个对象后,更新一下Id 字段
的值,因为它认为@Id 字段是默认自动增长的。如果想消除这个特
性,由你自己来控制@Id字段的值,请这样 @Id() 来
声明你的 ID 字段
字段声明,告诉 本字段将作为一个Name来使用。一个实
体的@Name 一般在数据表中都会做了唯一性约束。 所以当你依靠
@Name 来获取一个对象的时候,相当于
Sql代码
1. SELECT * FROM table WHERE name='...';
@NotNull 字段声明, 如果你试图 插入或者更新一个对象,给该字
@Id
@Name
段赋null值将导致一个MakeSQLException
字段声明,告诉 本字段默认的值。 @Default("你的默认
值") 这个默认值你可以写成动态的,比如
@Default @Default("${name}@") 当你插入的对象包括一个name 属
性,这个属性值会替换 ${name} 否则会用 ""(空串) 来替换
${name}
@Readonly 声明成Readonly的字段在插入和更新时将被忽略
在一个字段上声明一条一对一映射,这个声明需要你输入两个参数:
1. target: 你的这个字段对应的实体类。通常,这个类得是你
的字段的一个子类或者实现类。或者它能够顺利的通过
转换成你的字段。(
在 Book 里,我
@One
们将详细讨论 Nutz 为你提供的这个崭新的转换框架。在
中,这个框架几乎对你是透明的,只有极特殊的时
候有可能你需要关心它
)
2. field: 参考字段名,这个字段必须存在当前对象上。
声明一条多对多映射,这个声明需要你输入三个参数,其中一个是
可选的:
1. target: 对应的实体类名,意义和@One 一样
2. field: 参考字段名,同 @One不同,这个参考字段是 target
类中的字段。
3. key: 当你的字段类型是个Map 的时候,这个参数就有作用
了。 因为 @Many 通常会被你加在一个数组字段,或者一个
Collection 字段上,当你打算将 @Many 加在一个 Map 字段
上, 通过这个参数就可以知道,你的 Map 打算用
目标对象的哪一个属性作为 key,从而正确为你的建立 Map。
注意, @Many 是一个略微让人疑惑的名称,你可能会想,你声明
@Many 的字段必须是一个容器或者数组,其实,它也可以是一个单
个对象。对于 来说,@Many字段确切的意义是说:参考字
段(@) 是存放在 target 对象里的,而 @One则表示参考
字段是存放在当前对象的。 所以@Many 的确切意思是说“Can be
Many”,因此你甚至可以这么写
@Many(target=,field="id")private A a;那么你通过
any() 将只返回一个结果。
多对多的关联是数据库非常常见的一种设计,两个数据表通过第三
@ManyMany
张数据表进行关联,同@One 和 @Many 一样, 提供了一
@Many
版权声明:本文标题:实体注释(Entity 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.roclinux.cn/p/1717316405a704772.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论