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],当Model字段的名称和数据表的字段名称对应不上的时候会出现异常
当Model的字段总数小于数据表字段的总数的时候,是没有问题的。
当Model的字段总数多余数据表字段的总数的时候,会出现异常。
原因是查询的时候会将model的属性当成SQL检索的字段,如果字段不一样,或者属性名称不存在数据表字段里,就会报字段不存在的错误。No1:之前项目中hibernate对Integer参数注入String类型值进行模糊查询,并不会抛出异常。最近接触Spring Data JPA在写demo的过程中发现JPA对Integer的模糊查询支持比较差,无论是简单查询还是复杂查询均不支持。
注:equal无影响,仍可使用String参数注入
No2:自定义接口方法中,属性有几个,则参数要有几个。
注意:多了也不行
No3:查看JpaRepository具体实现类可发现在repository层已加事务,但是如何在service层控制事务?:
简单查询(zipCode是Integer类型):
复杂查询(假设sex也是zipCode):
mysql:
两个属性,一个参数
两个属性,两个参数
正常 *** 作结果会导致数据不回滚,正常插入
增加@Transactional,则数据回滚
1虽然说正常情况下Integer是不应该模糊查询的,但是也许就有用到。当使用JPA开发项目时,可能需要模糊查询的字段,尽量用String。@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 。
应该使用User类的属性名:sumScore,而不是使用数据库表的字段名sum_score
看一下Spring的orgspringframeworkdatajparepositoryqueryQueryUtils
方法toJpaOrder的第一行
PropertyPath property = PropertyPathfrom(ordergetProperty(), fromgetJavaType());由于Spring在解析你的排序条件时自身使用下划线作为字段匹配的分隔符
SPLITTERmatcher("_" + itpath);while(matcherfind()) {
iteratorSourceadd(matchergroup(1));
}
所以sum_score会被它拆成两个字段sum和score,而你的表里没有这两个字段,所以会报错。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)