SQLGrammarException 是由 Hibernate 或 JPA 抛出的异常,表示无法执行 SQL 语句,通常是由于 SQL 语法错误或数据映射不匹配导致的。...Hibernate 会尝试将 Java 对象转换成数据库中的表记录,当这种转换过程中出现问题时,Hibernate 会抛出这个异常。 2....可能原因和解决方案 2.1 实体类与数据库表字段不匹配 如果实体类与数据库表的字段定义不一致,可能导致 SQL 无法执行。...= null ) 2.2 数据库约束冲突 违反主键、唯一键、外键等约束可能导致无法插入或更新记录,进而产生 SQLGrammarException 异常。...解决方案: 确保数据库中的表具有正确的主键和外键约束。 插入或更新数据时,确保满足表的约束条件。
处理校验异常 5. 自定义约束 6. 分组校验 7. 手动校验 8. 国际化 i18n 666....2.2 Hibernate Validator 附加的约束注解 org.hibernate.validator.constraints 包下,定义了一系列的约束( constraint )注解。...省略 setting/getting 方法 } 每个字段上的约束注解,胖友仔细瞅瞅。...在大多数项目中,无论是 Bean Validation 定义的约束,还是 Hibernate Validator 附加的约束,都是无法满足我们复杂的业务场景。所以,我们需要自定义约束。...是的~实际上,国际化是个大工程,涉及到方方面面。例如说,业务信息表的国际化,商品同时支持中文、英文、韩文等多种语言。? 最近艿艿手头有个新项目,需要做国际化,有这方面需求的胖友,可以一起多多交流呀。
如果对于下面的处理异常的代码不太理解的话,可以查看这篇文章 《SpringBoot 处理异常的几种常见姿势》。 ?...通过使用@Validated和@Valid注释的组合即可实现这一需求! 一般情况下,我们在项目中也更倾向于使用这种方案。...输出结果如下: sex 值不在可选范围 name 不能为空 自定以 Validator(实用) 如果自带的校验注解无法满足你的需求的话,你还可以自定义实现注解。...被注释的元素必须是一个将来的日期 @Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式 Hibernate Validator 提供的校验注解: @NotBlank(message...总结来说就是即前者用于验证,而后者则用于指示数据库创建表的时候对表的约束。
Validator 是 Bean Validation 的参考实现 ,除了Jakarta Bean验证API定义的约束之外,Hibernate Validator还有一些附加的 constraint;...没有添加分组属性时,默认验证没有分组的验证属性(Default分组); @Validated:可以用在类型、方法和方法参数上,但是不能用在成员属性(字段)上; @Validated:用在方法入参上无法单独提供嵌套验证功能...,也无法提示框架进行嵌套验证。...实际上我们可以用到Hibernate-Validator的分组功能,达到对不同场景做出不同的校验逻辑,减少DTO对象的创建。...创建自定义注解@Sex,该注解是放在字段上的,也可以根据业务场景放在方法或者Class上面)用于判断性别是否符合约束 @Target({ ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME
需求背景 我们在写存储过程的时候,可能会出现下列⼀些情况: 1. 插⼊的数据违反唯⼀约束,导致插⼊失败 2....准备数据 创建库:javacode2018 创建表:test1,test1表中的a字段为主键。...我们将异常分为mysql内部异常和外部异常 mysql内部异常 当我们执⾏⼀些sql的时候,可能违反了mysql的⼀些约束,导致mysql内部报错,如插⼊ 数据违反唯⼀约束,更新数据超时等,此时异常是由...上⾯的结果和我们期望的不⼀致,我们希望要么都插⼊成功,要么失败。 那我们怎么做呢?我们需要捕获上⾯的主键约束异常,然后发现有异常的时候执⾏ rollback回滚操作,改进上⾯的代码,看下⾯⽰例2。...示例2 我们对上⾯⽰例进⾏改进,捕获上⾯主键约束异常,然后进⾏回滚处理,如下: 创建存储过程: /*删除存储过程*/ DROP PROCEDURE IF EXISTS proc2; /*声明结束符为$
Hibernate Validator 是JSR-303的参考实现,它提供了JSR 303规范中所有的约束(constraint)的实现,同时也增加了一些扩展。...Hibernate Validator 提供的常用约束注解 约束注解 详细信息 @Null 被注释的元素必须为 null @NotNull 被注释的元素必须不为 null @AssertTrue 被注释的元素必须为...不信你可以试一试,起码在Spring Boot 2.3.1.RELEASE是不会直接生效的。 使以上两种生效的方法是在类上添加@Validated注解。注意一定要添加到方法所在的类上才行。...注意一定要添加到方法所在的类上才行。这时候会抛出ConstraintViolationException异常。 嵌套校验不生效 嵌套的结构如何校验呢?...总结 通过校验框架我们可以专心于业务开发,本文对Hibernate Validator的使用和一些常见问题进行了梳理。我们可以通过Spring Boot 统一异常处理来解决参数校验的异常信息的提示问题
建模者必须能够用非技术企业专家可以理解的术语在概念层次上与数据结构进行通讯。建模者也必须能以简单的单元分析信息,对样本数据进行处理。ORM专门被设计为改进这种联系。 ...支持,将创建的session绑定到本地线程中,底层使用ThreadLocal,在程序之间共享Session。...即:会自动创建表结构和自动维护表结构。 create(很少):无论是否存在表结构。每次启动Hibernate都会重新创建表结构(数据会丢失)。 ...create-drop(极少):无论是否存在表结构。每次启动Hibernate都会重新创建表结构,每次Hibernate运行结束时,删除表结构。 ...validate(很少):不会自动创建表结构。也不会自动维护表结构。Hibernate只校验表结构,如果表结构不一致将会抛出异常。
show create table sicimike; # 添加表注释 alter table sicimike comment '表注释'; # 添加字段注释 alter table sicimike...第二范式 定义:数据库中的表不存在非关键字段对任一关键字字段的部分函数依赖 部分函数依赖是指存在着组合关键字中的某一关键字决定非关键字的情况 第二范式在满足了第一范式的基础上,消除非主键列对联合主键的部分依赖...第三范式是在满足了第二范式的基础上,消除列与列之间的传递依赖。 ? 在上面的表中,商品的分类描述依赖分类,而分类依赖商品名称,而不是分类描述直接依赖商品名称。这样就形成了传递依赖,所以不符合第三范式。...反范式设计时,需要考虑以下几个问题,分别是插入异常、更新异常和删除异常。 插入异常:如果某个实体随着另一个实体的存在而存在,即缺少某个实体是无法表示这个实体,那么这个表就存在插入异常。...如果可乐第二制造厂这个供应商尚未开始供货,表中就不存在第二条记录,也就无法记录供应商的电话,这样就存在插入异常;如果需要把可乐的价格提高,需要更新表中的多条记录,这样就存在更新异常;如果删除可乐第二制造厂的供货信息
https://github.com/CodingDocs/springboot-guide 码云地址:https://gitee.com/SnailClimb/springboot-guide(Github无法访问或者访问速度比较慢的小伙伴可以看码云上的对应内容...通过使用@Validated和@Valid注释的组合即可实现这一需求! 一般情况下,我们在项目中也更倾向于使用这种方案。...第一步,你需要创建一个注解 Region。...被注释的元素必须是一个将来的日期 @Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式 Hibernate Validator 提供的校验注解: @NotBlank(message...总结来说就是即前者用于验证,而后者则用于指示数据库创建表的时候对表的约束。 我是 Guide哥,拥抱开源,喜欢烹饪。Github 接近 10w 点赞的开源项目 JavaGuide 的作者。
表的约束,实质上就是用数据类型去约束字段,但是数据类型的约束手法很单一,比如,我们在设置身份证号这个字段,数据类型唯一起的约束是它属于char类型或者varchar类型,不能是浮点型也不能是日期时间类型...添加主键 添加主键的方法:①创建表的时候直接在字段上指定主键。②当表创建好以后但是没有主键的时候,可以再次追加主键。...举例: ①在创建表的时候直接在字段上指定主键,如表tt15,id为学生学号,为主键。查看表结构的时候,发现取值Key一列上,id被添加上了PRI,表示主键的意思。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯 一键。...:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。
我个人觉得这个和统一异常处理一样是后端很容易做好的一件事情,同时也是很有必要的事情。如果对后端如何统一异常处理不太清楚的朋友,也可以留言一下,我后面会分享自己在项目中学到的统一异常处理的方法。...@Future 被注释的元素必须是一个将来的日期 @Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式 Hibernate Validator提供的校验注解: @...一定一定不要忘记在类上加上 Validated 注解了,这个参数可以告诉 Spring 去校验方法参数。...@Autowired Validator validate 自定以 Validator(实用) 如果自带的校验注解无法满足你的需求的话,你还可以自定义实现注解。...总结来说就是即前者用于验证,而后者则用于指示数据库创建表的时候对表的约束。
使用@Validated时也需要放在参数列表中,放在类上和放在方法上都会导致没有校验。...对于这种情况,需要在入参上直接声明约束注解(如@Min()),并在类上标注@Validated注解。 注意:在类级别上标注@Validated注解告诉Spring需要校验方法参数上的约束。...@RequestBody接收json数据时,必须在方法的参数列表里面使用@Valid或@Validated来告诉hibernate-validator需要校验参数封装实体的字段约束(被标注到字段上的校验注解...),然后在需要嵌套校验的字段上标注@Valid注解,因为@Validated是不能使用在类的字段上的,所以只能使用@Valid 四、分组校验 通常,某些Java Bean在不同的请求之间共享。...mobile; // 仅仅作为一个标记接口 public interface OnUpdate{} public interface OnCreate{} } 三个字段标明在创建操作时需要校验
Hibernate框架提供对XML和JPA注释的支持,这使我们的代码实现独立。 Hibernate提供了一种与SQL类似的强大查询语言(HQL)。...Hibernate支持继承,关联和集合。JDBC API不提供这些功能。 Hibernate隐式提供事务管理,实际上,大多数查询无法在事务外部执行。...JDBC API抛出SQLException ,这是一个已检查的异常,因此我们需要编写许多try-catch块代码。在大多数情况下,它在每个JDBC调用中都是多余的,用于事务管理。...Hibernate包装JDBC异常并抛出JDBCException或HibernateException未经检查的异常,因此我们不需要编写代码来处理它。...Hibernate支持更好的性能缓存,不缓存JDBC查询,因此性能低下。 Hibernate提供了一些选项,通过它们我们也可以创建数据库表,因为JDBC表必须存在于数据库中。
这种方式将主键自增长的任务完全交给数据库,我们无需在代码层面上进行任何控制。 第二种,通过序列以及Hibernate配置实现自增长。 这种方式适用于通过Hibernate连接数据库的方式。...这种方式在数据库上创建序列,通过配置在POJO类上的注释,让Hibernate去调用数据库的序列实现自增长。...因为如果通过第一种方式进行配置,则Hibernate无法获取到其主键的值,在插入的时候Hibernate会提示:父类主键未找到(即主键无值)。...进一步,Hibernate的级联增加也会因为无法获取到主键而无法插入数据到关系表中。...with 1; 接着,把POJO类主键上的注释改为: 1 @Id 2 @SequenceGenerator(name = "prodG",sequenceName="PRODUCT_ID_SEQ
而如果为我们没有在创建表的时候显示声明默认值,MySQL会优化,自动加上默认值为NULL。 四....列描述 列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA(数据库管理员)来进行了解。 可以看到通过desc是看不到注释信息的,得用show才能看到。...其实我们可以在创建表的时候就指定: 这样就指定初始为500。...唯一键 创建带有唯一键的表: 唯一键表达了类似于主键的功能,不能发生冲突。 但是,唯一键是可以为空的,这是区别于主键的地方。 主键与唯一键并不冲突,是互相补充的!!!...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。
实际上,default就是在创建表之前将缺省值也插入进去。...四.列描述comment 实际上comment描述的设置并不会阻止数据进行插入,其可以等同于注释,即对列的介绍。 那为什么还说comment是一种约束呢?实际上什么都约束不了啊?...1.唯一主键 创建表时约束某一字段为主键。 为了保证不能重复,不能为空,相应的创建语句在mysqld中也会添加not null,Key也会标记PRI保证不能重复。...唯一键允许为空,而且可以多个为空,因为空字段不做唯一性比较。 唯一键和主键的区别: 在使用中,主键是标识唯一性,而唯一键是保证业务中的数据唯一性。 主键一个表只能有一个,唯一键可以有多个。...在插入数据中,telephone作为业务上的数据,不能出现重复,一旦插入出现纰漏,将相同的telephone的数据给了不同的id,那么就造成了无法精准确定个人信息的情况,为了避免这种情况的发生,就需要将
领取专属 10元无门槛券
手把手带您无忧上云