• hibernate中错误解决


    第一次写问题记录,在网上找了许久但还没解决

    hibernate.hbm2ddl.auto">update

    设置成update,应该是会自动生成表。但是它却没生成。

    1. package hibernatetest;
    2. import org.hibernate.Session;
    3. import org.hibernate.SessionFactory;
    4. import org.hibernate.Transaction;
    5. import org.hibernate.cfg.Configuration;
    6. import org.junit.Test;
    7. import entity.User;
    8. public class HibernateDemo {
    9. @Test
    10. public void testAdd2() {
    11. Configuration cfg=new Configuration();
    12. cfg.configure();
    13. SessionFactory sessionFactory=cfg.buildSessionFactory();
    14. Session session= sessionFactory.openSession();
    15. Transaction tx=session.beginTransaction();
    16. User user=new User();
    17. user.setUsername("小米");
    18. user.setPassword("123456");
    19. user.setAddress("中国");
    20. session.save(user);
    21. tx.commit();
    22. session.close();
    23. sessionFactory.close();
    24. }
    25. }
    1. "1.0" encoding="UTF-8"?>
    2. <class name="entity.User" table="user">
    3. "uid" column="uid" >
    4. "native">
    5. "username" column="username">
    6. "password" column="password">
    7. "address" column="address">

     

    1. package entity;
    2. public class User {
    3. private int uid;
    4. private String username;
    5. private String password;
    6. private String address;
    7. public User() {
    8. super();
    9. }
    10. public User(int uid, String username, String password, String address) {
    11. super();
    12. this.uid = uid;
    13. this.username = username;
    14. this.password = password;
    15. this.address = address;
    16. }
    17. public int getUid() {
    18. return uid;
    19. }
    20. public void setUid(int uid) {
    21. this.uid = uid;
    22. }
    23. public String getUsername() {
    24. return username;
    25. }
    26. public void setUsername(String username) {
    27. this.username = username;
    28. }
    29. public String getPassword() {
    30. return password;
    31. }
    32. public void setPassword(String password) {
    33. this.password = password;
    34. }
    35. public String getAddress() {
    36. return address;
    37. }
    38. public void setAddress(String address) {
    39. this.address = address;
    40. }
    41. @Override
    42. public String toString() {
    43. return "User [uid=" + uid + ", username=" + username + ", password=" + password + ", address=" + address + "]";
    44. }
    45. }
    1. "1.0" encoding="UTF-8"?>
    2. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    3. "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
    4. "hibernate.connection.driver_class">com.mysql.jdbc.Driver
    5. "hibernate.connection.url">jdbc:mysql:///studInfo
    6. "hibernate.connection.username">root
    7. "hibernate.connection.password">123456
    8. "hibernate.show_sql">true
    9. "hibernate.format_sql">true
    10. "hibernate.hbm2ddl.auto">update
    11. "hibernate.dialect">org.hibernate.dialect.MySQLDialect
    12. "entity/User.hbm.xml"/>

     

    在JUnit中进行测试的时候,却报出了错:

    org.hibernate.exception.SQLGrammarException: could not execute statement
    at org.hibernate.exception.internal.SQLExceptionTypeDelegate.convert(SQLExceptionTypeDelegate.java:63)
    at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:111)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:97)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:208)
    at org.hibernate.dialect.identity.GetGeneratedKeysDelegate.executeAndExtract(GetGeneratedKeysDelegate.java:57)
    at org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:42)
    at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2909)
    at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3480)
    at org.hibernate.action.internal.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:81)
    at org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:626)
    at org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:280)
    at org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:261)
    at org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:306)
    at org.hibernate.event.internal.AbstractSaveEventListener.addInsertAction(AbstractSaveEventListener.java:318)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:275)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:182)
    at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:113)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:192)
    at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:38)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:177)
    at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:32)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:73)
    at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:689)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:681)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:676)
    at cn.itcast.hibernateTest.HibernateDemo01.add(HibernateDemo01.java:46)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    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:459)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)
    Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 't_user.t_newuser' doesn't exist
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:425)
    at com.mysql.jdbc.Util.getInstance(Util.java:408)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:943)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3973)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3909)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2527)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2680)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2490)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1858)
    at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2079)
    at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2013)
    at com.mysql.jdbc.PreparedStatement.executeLargeUpdate(PreparedStatement.java:5104)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1998)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:205)
    ... 45 more

    ------------------------------------已解决--------------------------分割线----------------------------------------

    此文代码是使用Junit进行单元测试,不是完整的Hibernate项目。

    在进行Junit测试时,eclipse没有在数据库创建表格。所以报出表不存在的问题。

    解决操作是在数据库中先建立好表格,字段要求与代码一致。

    最重要的是在数据库中的主键,要有设置成“自动递增”的一项。

    否则在运行时,会报出“xxxx doesn't have a default value”的错误。


    设置自动递增


    完成数据库的表创建后,进行JUnit测试,成功。

    数据库了更新了内容
    ————————————————
    版权声明:本文为CSDN博主「saimer1220」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/saimer1220/article/details/72795045

  • 相关阅读:
    基于Boost的搜索引擎
    安卓sd卡格式化数据恢复方法,您了解吗
    【高阶数据结构】哈希(哈希表、哈希桶)
    C# 连接SQL Sever 数据库与数据查询实例 数据仓库
    两个链表的第一个公共结点
    pytest合集(13)— 插件管理
    An Information-Theoretic Framework for Semi-Supervised Multi-Modality Learning
    GESP-9月
    < element组件封装: element表格(element-table)实现表格列筛选功能组件 >
    Elasticsearch
  • 原文地址:https://blog.csdn.net/m0_54397364/article/details/127876938