Hibernate 使用命令提示符进行简单休眠

Hibernate 使用命令提示符进行简单休眠,hibernate,jar,command-prompt,Hibernate,Jar,Command Prompt,我已经编写了一个简单的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 getFirstNa

我已经编写了一个简单的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;
 }

}
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();
    }
   }
  }
 }
FirstExample.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;
 }

}
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>
</hibernate-mapping>

请帮帮我。提前感谢。

在类路径中添加log4j.jar或从类路径中删除slf4j-log4j12-1.5.5.jar

在类路径中添加log4j.jar或从类路径中删除slf4j-log4j12-1.5.5.jar

如果包含slf4j-log4j.jar,则还必须包含log4j-jar。Slf4j是一个日志外观,这意味着它为您提供了一个到多个其他日志API的统一接口

如果包含slf4j-log4j.jar,那么还必须包含log4j jar。Slf4j是一个日志外观,这意味着它为您提供了一个到多个其他日志API的统一接口

我添加了jar文件。但我仍然有其他错误。线程“main”java.lang.NoSuchFieldError中出现异常:org.slf4j.impl.Log4jLoggerAdapter.share上的名称共享最新错误。顺便说一句,当您使用log4jjar时,您需要添加log4j.properties或xml文件。如果其他编码正确与否,请告诉我!非常感谢。看起来slf4j-log4j12-1.5.5.jar版本和您使用的log4j jar版本不匹配。我觉得您的代码没问题。那么我应该使用哪个版本。。我也尝试了不同版本的jar文件,我添加了jar文件。但我仍然有其他错误。线程“main”java.lang.NoSuchFieldError中出现异常:org.slf4j.impl.Log4jLoggerAdapter.share上的名称共享最新错误。顺便说一句,当您使用log4jjar时,您需要添加log4j.properties或xml文件。如果其他编码正确与否,请告诉我!非常感谢。看起来slf4j-log4j12-1.5.5.jar版本和您使用的log4j jar版本不匹配。我觉得您的代码没问题。那么我应该使用哪个版本。。我尝试了不同版本的jar文件,程序也可以运行。。但无法使用我通过对象传递的信息更新表。但是它创建了表..你能共享代码吗?您可以为同一个线程启动一个新线程。该程序可以运行。。但无法使用我通过对象传递的信息更新表。但是它创建了表..你能共享代码吗?您可以为同一个线程启动一个新线程。