Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/hibernate/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Hibernate 无法更新该表_Hibernate_Command Prompt_Sql Update - Fatal编程技术网

Hibernate 无法更新该表

Hibernate 无法更新该表,hibernate,command-prompt,sql-update,Hibernate,Command Prompt,Sql Update,我已经编写了一个简单的hibernate应用程序,它不会更新表。下面是我的代码。表已创建,但未更新 **Contact.java** public class Contact { private String firstName; private String lastName; private String email; private long id; public String getEmail() { return email; } public String getFir

我已经编写了一个简单的hibernate应用程序,它不会更新表。下面是我的代码。表已创建,但未更新

**Contact.java**

 public class Contact {
private String firstName;
private String lastName;
private String email;
private long id;

public String getEmail() {
    return email;
}

public String getFirstName() {
    return firstName;
}

public String getLastName() {
    return lastName;
}

public void setEmail(String string) {
    email = string;
}

public void setFirstName(String string) {
    firstName = string;
}

public void setLastName(String string) {
    lastName = string;
}

public long getId() {
    return id;
}

public void setId(long l) {
    id = l;
}

}
FirstExample.java

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class FirstExample {
public static void main(String[] args) {
    Session session = null;

    try {

        SessionFactory sessionFactory = new Configuration().configure()
                .buildSessionFactory();
        session = sessionFactory.openSession();

        System.out.println("Inserting Record");
        Contact contact = new Contact();
        contact.setId(3);
        contact.setFirstName("Tausif");
        contact.setLastName("rahmathullah");
        contact.setEmail("t.r@vl.net");
        session.save(contact);
        System.out.println("updated");
    } catch (Exception e) {
        System.out.println(e.getMessage());
        e.printStackTrace();
    } finally {
        if (session != null) {
            session.flush();
            session.close();
        }
    }
}
}
hibernate.cfg.xml

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
 <session-factory>
  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
  <property name="hibernate.connection.url">jdbc:mysql://localhost/simpHiber</property>
  <property name="hibernate.connection.username">root</property>
  <property name="hibernate.connection.password">root</property>
  <property name="hibernate.connection.pool_size">10</property>
  <property name="show_sql">true</property>
  <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
  <property name="hibernate.hbm2ddl.auto">update</property>
  <mapping resource="contact.hbm.xml"/>
 </session-factory>
</hibernate-configuration>
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
 <class name="Contact" table="CONTACT">
  <id name="id" type="long" column="ID" >
  <generator class="assigned"/>
  </id>

 <property name="firstName">
 <column name="FIRSTNAME" />
 </property>
 <property name="lastName">
 <column name="LASTNAME"/>
 </property>
 <property name="email">
 <column name="EMAIL"/>
 </property>
</class>

com.mysql.jdbc.Driver
jdbc:mysql://localhost/simpHiber
根
根
10
真的
org.hibernate.dialogue.mysql5dialogue
更新
contact.hbm.xml

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
 <session-factory>
  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
  <property name="hibernate.connection.url">jdbc:mysql://localhost/simpHiber</property>
  <property name="hibernate.connection.username">root</property>
  <property name="hibernate.connection.password">root</property>
  <property name="hibernate.connection.pool_size">10</property>
  <property name="show_sql">true</property>
  <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
  <property name="hibernate.hbm2ddl.auto">update</property>
  <mapping resource="contact.hbm.xml"/>
 </session-factory>
</hibernate-configuration>
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
 <class name="Contact" table="CONTACT">
  <id name="id" type="long" column="ID" >
  <generator class="assigned"/>
  </id>

 <property name="firstName">
 <column name="FIRSTNAME" />
 </property>
 <property name="lastName">
 <column name="LASTNAME"/>
 </property>
 <property name="email">
 <column name="EMAIL"/>
 </property>
</class>


由于您正在使用then
assigned
作为id,因此每次保存时都需要设置不同的id

    Contact contact = new Contact();
    contact.setId(3);//Change the id every time you insert.
    contact.setFirstName("Tausif");
    contact.setLastName("rahmathullah");
    contact.setEmail("t.r@vl.net");
    session.save(contact);
现在,如果要更新条目而不是再次插入,请使用,

    session.saveOrUpdate(contact);

如果数据库中存在
id
,则会触发更新查询;如果数据库中不存在,则会插入更新查询。

在应用程序中使用log4j时,有时可能会遇到以下消息:


log4j:WARN找不到记录器(somePackageName.someClassName)的追加器。 log4j:警告请正确初始化log4j系统


看到此消息的原因是在类路径中找不到log4j配置文件(即
log4j.xml
log4j.properties
)。将log4j配置文件放在应用程序
classpath
中应该可以解决这个问题


还有一件事,这不是一个错误。这是一个警告。这意味着它在工作时会产生任何问题。

您是否可以在问题中添加一些日志记录以及程序的任何输出。在eclipse的控制台或日志文件中。这是在尝试解决任何问题时需要注意的最有用的内容Log4j:WARN找不到记录器(org.hibernate.type.BasicTypeRegistry)的附加程序。log4j:警告请正确初始化log4j系统。插入记录更新Hibernate:插入联系人(名字、姓氏、电子邮件、ID)值(?、、?、?)看到此消息的原因是在类路径中找不到log4j配置文件(即log4j.xml或log4j.properties)。将log4j配置文件放在应用程序类路径中应该可以解决这个问题。我得到一个错误log4j:WARN找不到记录器(org.hibernate.type.BasicTypeRegistry)的附加器。log4j:WARN请正确初始化log4j系统。插入记录休眠:选择contact_uu.ID,contact_u.FIRST_uname作为FIRST2_u0,contact_u.LAST_uname作为LAST3_0,contact_u.EMAIL作为EMAIL0_uFr om contact_u其中contact_u.ID=?更新的Hibernate:在联系人(名字、姓氏、电子邮件、ID)中插入不是错误的值(?、、?、?)。你看到DB了吗?你怎么知道没有插入行?是的。我检查了数据库。它显示列,但为空集。已创建表,但未插入数据。