org.hibernate.exception.ConstraintViolationExcepti

org.hibernate.exception.ConstraintViolationException: could not execute statement
 at org.hibernate.exception.internal.SQLStateConversionDelegate.convert(SQLStateConversionDelegate.java:129)
 at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:49)
 at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:126)
 at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:112)
 at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:190)
 at org.hibernate.id.IdentityGenerator$GetGeneratedKeysDelegate.executeAndExtract(IdentityGenerator.java:96)
 at org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:58)
 at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3032)
 at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3558)
 at org.hibernate.action.internal.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:97)
 at org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:488)
 at org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:193)
 at org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:177)
 at org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:212)
 at org.hibernate.event.internal.AbstractSaveEventListener.addInsertAction(AbstractSaveEventListener.java:324)
 at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:288)
 at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:194)
 at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:125)
 at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:209)
 at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:55)
 at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:194)
 at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:49)
 at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:90)
 at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:715)
 at org.hibernate.internal.SessionImpl.save(SessionImpl.java:707)
 at org.hibernate.internal.SessionImpl.save(SessionImpl.java:702)
 at com.fnst.group03.dao.Impl.CommentsDaoImpl.save(CommentsDaoImpl.java:29)
 at com.fnst.group03.service.Impl.UserServiceImpl.sendComments(UserServiceImpl.java:213)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:606)
 at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:317)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:190)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
 at org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation(TransactionInterceptor.java:98)
 at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:262)
 at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:95)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
 at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
 at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207)
 at com.sun.proxy.$Proxy18.sendComments(Unknown Source)
 at com.fnst.group03.service.JUserService.testSendComments(JUserService.java:148)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 at java.lang.reflect.Method.invoke(Method.java:606)
 at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
 at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
 at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
 at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
 at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
 at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
 at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
 at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
 at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
 at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
 at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
 at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
 at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
 at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
 at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
 at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
 at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
 at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
 at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: com.mysql.jdbc.exceptions.MySQLIntegrityConstraintViolationException: Cannot add or update a child row: a foreign key constraint fails (`fnst2_club`.`comments`, CONSTRAINT `fk_comments_talk1` FOREIGN KEY (`talk_id`) REFERENCES `talk` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION)
 at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:931)
 at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)
 at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631)
 at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723)
 at com.mysql.jdbc.Connection.execSQL(Connection.java:3283)
 at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1332)
 at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1604)
 at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1519)
 at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1504)
 at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeUpdate(NewProxyPreparedStatement.java:147)
 at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:187)
 ... 62 more

错误是,comments表中有外键talk_id,在保存时talk_id的值为  1,但是在talk中并没有id为1的记录

换句话说,comments 中的 字段 talk_id 指向 表talk  为一条空记录

转载于:https://my.oschina.net/fuluS/blog/348946

### 回答1: "org.hibernate.exception.sqlgrammarexception" 是一个 Hibernate 框架中的异常类型,表示 SQL 语法错误异常。在使用 Hibernate 进行数据库操作时,如果使用的 SQL 语句存在语法错误,则会抛出此异常。需要检查 SQL 语句是否符合语法规范,并且查看相关日志信息,以找出异常的具体原因。 ### 回答2: org.hibernate.exception.sqlgrammarexceptionHibernate 框架中的一个异常类型,它表示在执行 SQL 语句期间出现了语法错误。这个异常通常是由于 SQL 语句中存在错误的语法或语义所导致的。当 Hibernate 尝试执行查询或更新时,如果 SQL 语句无效,则会抛出这个异常。 通常,这种异常可能的原因包括以下几种: 1. SQL 语句的语法有错误,比如拼写错误、用错了关键字等等。 2. SQL 语句中的参数不正确,比如错误地使用了一个没有定义的变量或者未正确绑定变量。 3. 数据库中的表结构发生了变化,导致 SQL 语句不再适用于当前的表结构。 4. 应用程序或数据库本身存在错误或故障,导致执行 SQL 语句失败。 解决这个异常的方法是,首先需要检查 SQL 语句是否正确,确保它们没有语法错误或语义错误。然后检查 Hibernate 框架中是否正确地绑定了所有参数。如果数据库的表结构发生了变化,则需要更新 SQL 语句以反映新的表结构。最后,考虑检查应用程序和数据库本身是否存在错误或故障,需要对应用程序和数据库进行排错。 总之,org.hibernate.exception.sqlgrammarexception 表示在执行 SQL 语句期间出现了语法错误,需要及时检查和修复问题,确保应用程序能够正常运行。 ### 回答3: org.hibernate.exception.sqlgrammarexceptionHibernate框架的一个异常类,表示在执行数据库语句时发生了语法错误的异常。 当我们使用Hibernate框架操作数据库时,执行的SQL语句通常是由Hibernate自动生成的。在这个过程中,如果存在语法错误,就会抛出org.hibernate.exception.sqlgrammarexception异常。 通常情况下,org.hibernate.exception.sqlgrammarexception异常的原因有以下几种: 1. SQL语句写错了。例如,缺失了关键字或者拼写错误等。 2. 字段名、表名或者数据库名写错了。例如,大小写敏感、名字拼写不一致等。 3. SQL语句中使用了不支持的SQL语法。例如,在MySQL中使用了Oracle特有的语法等。 4. 数据库访问权限不够。例如,用户没有访问该表的权限等。 当我们遇到org.hibernate.exception.sqlgrammarexception异常时,我们需要仔细检查SQL语句和数据库结构等方面,找到错误并及时纠正。在修复问题之前,也可以使用Hibernate提供的日志工具来追踪问题,帮助我们更快地定位问题。 另外,由于Hibernate封装了底层的JDBC操作,所以当我们碰到org.hibernate.exception.sqlgrammarexception异常时,一定要从Hibernate框架的角度去考虑问题,而不是直接去修改数据库。这样可以避免影响数据的安全性和一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值