发生这种异常的因素有可能:
jar包导入不正确或缺少jar包 (hibernate.jar);
直接添加hibernate.jar包。
解决问题的方法永远不止一个 ---->
如果有jar而且还不行试试另一种方法,
比如原来是:
hibernateTemplate.save(customer); (发生这种错误都会指向一条sql语句)
现在改成:
Session session = hibernateTemplate.getSessionFactory().openSession();
if(session !=null)
{
session.save(customer);
}
session.flush();
session.close();
还有一个情况就是向数据库插入为0的主键,那么修改数据库环境,
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO"
NO_AUTO_VALUE_ON_ZERO影响AUTO_INCREMENT列的处理。一般情况,你可以向该列插入NULL或0生成下一个序列号。NO_AUTO_VALUE_ON_ZERO禁用0,因此只有NULL可以生成下一个序列号。
如果将0保存到表的AUTO_INCREMENT列,该模式会很有用。(不推荐采用该惯例)。例如,如果你用mysqldump转储表并重载,MySQL遇到0值一般会生成新的序列号,生成的表的内容与转储的表不同。重载转储文件前启用NO_AUTO_VALUE_ON_ZERO可以解决该问题。
本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。