jpa 联合主键的sql 怎么写

jpa 联合主键的sql 怎么写,第1张

建立主键有两种方法:一种是在数据库提供的GUI环境中建立,另一种是通过SQL语句执行建立,下面分别介绍。
1在数据库提供的GUI环境中建立(以SQL7为例)。
输入表信息后按Ctrl键同时选中多行,然后点上面的主键按钮就行了。
2通过SQL语句执行建立。又分两种,一是在建表语句中直接写,二是建表之后更改表结构。
在建表语句中直接写:
Create Table 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null Primary Key (字段名1, 字段名2),
字段名3字段名N )建表之后更改表结构:
CREATE TABLE 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null字段名3字段名N)GOALTER TABLE 表名 WITH NOCHECK ADD
CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED([字段名1],

@[toc]

以Menu为例
每个菜单都有一个父菜单pid字段表示,同时还有许多个子菜单,所以Menu与自己属于many to one 和 one to many的关系

用@OneToMany注释子菜单字段,这里fetch=FetchTypeLAZY没用
这里@JoinColumn name属性值和之前的不同,这里pid是数据表里面的字段。

说乐观锁是个好东西,首先得说 JPA 是个好东西,因为Spring Data JPA已经内置了乐观锁的实现,给数据库表添加乐观锁很简单,添加一个整型字段,并加入@Version注解就可以了,每次提交数据时JPA会自动检查版本。 @Entity
@Table(name = "m_order")
public class Order {

@Version
private int version;

}

@Version @Version 默认情况下,JPA 持续性提供程序假设应用程序负责数据一致性。 使用 @Version 批注通过指定用作其乐观锁定值的实体类的版本字段或属性来 启用 JPA 管理的乐观锁定(推荐做法)。 选择版本字段或属性时,确保: · · 每个实体只有一个版本字段或属性 选择一个持久保存到主表的属性或字段(请参阅 @Table ) · 您的应用程序不修改版本属性或字段 此批注没有属性。有关更多详细信息,请参阅 API 。 示例 1-91 显示了如何使用此批注将属性 getVersionNum 指定为乐观锁定值。 在该示例中,该属性的列名设置为 OPTLOCK (请参阅 @Column ),而非属性的 默认列名。 示例 1-91 @Version @Entity public class Employee implements Serializable { @Version @Column(name="OPTLOCK") protected int getVersionNum() { return versionNum; } } @Column 默认情况下, JPA 持续性提供程序假设每个实体的持久字段存储在其名称与持久 字段的名称相匹配的数据库表列中。 使用 @Column 批注: 将持久字段与其他名称关联(如果默认列名难于处理、与事先存在的数据 模型不兼容或作为数据库中的列名无效) 将持久字段与辅助表中的列关联(请参阅 @SecondaryTable ) 微调数据库中列的特征 表 1-7 列出了此批注的属性。有关更多详细信息,请参阅 API 。 表 1-7 @Column 属性 属性 columnDefinition 必 需 说明 默认值:空 String 。 默认情况下,JPA 使用最少量 SQL 创建一个数据库表 列。 如果需要使用更多指定选项创建的列,请将 columnDefinition 设置为在针对列生成 DDL 时希望 JPA 使用的 SQL 片断。 注意:捕获批注中的 DDL 信息时,某些 JPA 持续性提 供程序可以在生成数据库模式时使用此 DDL 。

两种方式:
方式1:假设Bean的属性xxx为主键,则在getXxx() 前添加以下注解
@Id
@SequenceGenerator(name="名称A", sequenceName="库中已存在的sequence名称",allocationSize=递增值)
@GeneratedValue(strategy=GenerationTypeSEQUENCE, generator="名称A")
方式2:假设Bean的属性xxx为主键,则在getXxx() 前添加以下注解
@Id
@TableGenerator(name="名称A",allocationSize=递增值)//若不指定递增值,则生成的主键值不一定连续
@GeneratedValue(strategy=GenerationTypeTABLE, generator="名称A")
总结:方式1:针对Oracle效率略高,但需要手工创建sequence才能使用。
方式2:不依赖数据库,可移植性好,但相比方式1,效率略低。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13406039.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-30
下一篇 2023-07-30

发表评论

登录后才能评论

评论列表(0条)

保存