博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【01-06】JPA 全局单一主键
阅读量:7007 次
发布时间:2019-06-27

本文共 1853 字,大约阅读时间需要 6 分钟。

建一张主键表

@Override    public boolean equals(Object o) {        return (o == this || (o instanceof AbstractEntity && uid().equals(((AbstractEntity)o).uid())));    }
CREATE TABLE  tb_generator (  id int(20) unsigned NOT NULL auto_increment,  gen_name varchar(255) NOT NULL,  gen_value int(20) NOT NULL,  PRIMARY KEY  (id))INSERT INTO tb_generator ( gen_name ,gen_value ) VALUES ( 'CUSTOMER_PK',1);INSERT INTO tb_generator ( gen_name ,gen_value ) VALUES ( 'CONTACT_PK',100);

指定全局主键

@Id         @GeneratedValue(strategy = GenerationType.TABLE,generator="customer_gen")         @TableGenerator(name = "customer_gen",                            table="tb_generator",                            pkColumnName="gen_name",                            valueColumnName="gen_value",                            pkColumnValue="CUSTOMER_PK",                            allocationSize=1         )

JPA TableGenerator

@Target({TYPE, METHOD, FIELD}) @Retention(RUNTIME)public @interface TableGenerator {String name();String table() default "";String catalog() default "";String schema() default "";String pkColumnName() default "";String valueColumnName() default "";String pkColumnValue() default "";int initialValue() default 0;int allocationSize() default 50;UniqueConstraint[] uniqueConstraints() default {};}/*name表示该表主键生成策略的名称,它被引用在@GeneratedValue中设置的“generator”值中。table属性表示表生成策略所持久化的表名,例如,这里表使用的是数据库中的“tb_generator”。catalog属性和schema具体指定表所在的目录名或是数据库名。pkColumnName属性的值表示在持久化表中,该主键生成策略所对应键值的名称。例如在“tb_generator”中将“gen_name”作为主键的键值valueColumnName属性的值表示在持久化表中,该主键当前所生成的值,它的值将会随着每次创建累加。例如,在“tb_generator”中将“gen_value”作为主键的值pkColumnValue属性的值表示在持久化表中,该生成策略所对应的主键。例如在“tb_generator”表中,将“gen_name”的值为“CUSTOMER_PK”。initialValue表示主键初识值,默认为0。allocationSize表示每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50。UniqueConstraint与@Table标记中的用法类似*/

转载于:https://www.cnblogs.com/achievec/p/6254584.html

你可能感兴趣的文章
curl获取错误信息 php请求api接口方法
查看>>
织梦dedecms v5.7使用sql标签实现静态分页
查看>>
嵌入式工程师的发展路线
查看>>
Git命令集之七——差异查询命令
查看>>
kvm动态迁移
查看>>
Ubuntu14.04安装nodejs
查看>>
linux环境变量
查看>>
python为什么会作为***的首选语言?这几本书给你答案(已集齐)
查看>>
看过来!怎么恢复SD卡删除的文件?
查看>>
如何加快Python 应用的启动时间
查看>>
不可修改字符串NSString和可修改字符串NSMutableString
查看>>
django第一个app,4
查看>>
微信转发或分享朋友圈带缩略图、标题和描述的实现方法
查看>>
小程序一定要安装ssl证书吗
查看>>
Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'
查看>>
DB2 锁升级示例1
查看>>
启动网卡报错Failed to start LSB: Bring up/down network
查看>>
centos 升级4.0 内核
查看>>
Ubuntu配置永久生效的alias总结
查看>>
Tcp/Ip Http Socket的区别
查看>>