今天看了一下12*給我的那個Hibernate的簡單實例,結果弄了一個下午才搞定.有點感想和大家分享一下下. 稍後會把程序貼出來給大家展示一下出錯地方.
1.開發環境eclipse3.2.1,mysql5.0
2, 首先是開發環境配置上,我最開始的時候是把Hibernate所需的jar導入到window--refrences-java-installed jar中,結果編譯好多次也不行,後來我就把jar全部刪除了,在我建的項目上單擊右鍵,選擇Properties-java build path中,選擇add external jars,將需要的jar加入即可
3,上面完成後我執行程序發現數據不能插入到數據庫,但是能夠顯示插入的sql語句,並且可以從數據庫取出數據,試了一下才發現原因是建表的時候沒有把主鍵ID設置爲自動增加,致使無法插入,原因是我在xml文件中配置的主鍵的時候使用了這個<generator class="identity"/>,而他所對應的數據庫主鍵必須是自動增加的,這只是我理解的,因爲實在找不出其他原因了^_^.
收穫就這麼點,還是給大家看看代碼吧:
所需jar文件:
antlr.jar
cglib.jar
asm.jar
asm-attrs.jar
common-collections.jar
common-logging.jar
ehcache.jar
hibernate3.jar
jta.jar
dom4j.jar
log4j.jar
mysql初始化語句:
# MySQL-Front 3.1 (Build 9.0)
# Host: localhost Database: demo
# ------------------------------------------------------
# Server version 5.0.22-community-nt
#
# Table structure for table user
#
CREATE TABLE `user` (
`id` int(6) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`age` int(6) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
#
# Dumping data for table user
#
INSERT INTO `user` VALUES (1,'david',23);
INSERT INTO `user` VALUES (2,'caterpillar',30);
INSERT INTO `user` VALUES (3,'caterpillar',30);
# MySQL-Front 3.1 (Build 9.0)
# Host: localhost Database: demo
# ------------------------------------------------------
# Server version 5.0.22-community-nt
#
# Table structure for table user
#
CREATE TABLE `user` (
`id` int(6) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`age` int(6) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
#
# Dumping data for table user
#
INSERT INTO `user` VALUES (1,'david',23);
INSERT INTO `user` VALUES (2,'caterpillar',30);
INSERT INTO `user` VALUES (3,'caterpillar',30);
# MySQL-Front 3.1 (Build 9.0)
# Host: localhost Database: demo
# ------------------------------------------------------
# Server version 5.0.22-community-nt
#
# Table structure for table user
#
CREATE TABLE `user` (
`id` int(6) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`age` int(6) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
#
# Dumping data for table user
#
INSERT INTO `user` VALUES (1,'david',23);
INSERT INTO `user` VALUES (2,'caterpillar',30);
INSERT INTO `user` VALUES (3,'caterpillar',30);
# MySQL-Front 3.1 (Build 9.0)
# Host: localhost Database: demo
# ------------------------------------------------------
# Server version 5.0.22-community-nt
#
# Table structure for table user
#
CREATE TABLE `user` (
`id` int(6) NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`age` int(6) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
#
# Dumping data for table user
#
INSERT INTO `user` VALUES (1,'david',23);
INSERT INTO `user` VALUES (2,'caterpillar',30);
INSERT INTO `user` VALUES (3,'caterpillar',30);
數據庫配置文件:用戶名和密碼根據自己數據庫設置的進行修改
hibernate.cfg.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="show_sql">
true
</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="connection.url">
jdbc:mysql://localhost:3306/demo
</property>
<property name="connection.username">
root
</property>
<property name="connection.password">
851120
</property>
<!-- 以下設置物件與資料庫表格映射文件 -->
<mapping resource="onlyfun/caterpillar/User.hbm.xml"/>
<mapping resource="events/Event.hbm.xml"/>
</session-factory>
</hibernate-configuration>
user表對應的類:
package onlyfun.caterpillar;
public class User {
private Integer id;
private String name;
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
user對應的xml文件
User.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="onlyfun.caterpillar.User"
table="user">
<id name="id" column="id">
<generator class="identity"/>
</id>
<property name="name" column="name"/>
<property name="age" column="age"/>
</class>
</hibernate-mapping>
控制操作的接口:
package onlyfun.caterpillar;
public interface IUserDAO {
public void insert(User user);
public User find(Integer id);
}
接口實現
package onlyfun.caterpillar;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
public class UserDAO implements IUserDAO {
private SessionFactory sessionFactory;
public UserDAO() {
}
public UserDAO(SessionFactory sessionFactory) {
this.setSessionFactory(sessionFactory);
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public void insert(User user) {
// 取得Session
Session session = sessionFactory.openSession();
// 開啓事務
Transaction tx= session.beginTransaction();
// 直接儲存對象
session.save(user);
// 送出事務
tx.commit();
session.close();
}
public User find(Integer id) {
Session session = sessionFactory.openSession();
User user = (User) session.get(User.class, id);
session.close();
return user;
}
}
測試類:
package onlyfun.caterpillar;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class HibernateDemo {
public static void main(String[] args) {
// Configuration 負責管理 Hibernate 配置訊息
Configuration config =
new Configuration().configure();
// 根據 config 建立 SessionFactory
// SessionFactory 將用於建立 Session
SessionFactory sessionFactory =
config.buildSessionFactory();
// 建立DAO對象
IUserDAO userDAO = new UserDAO(sessionFactory);
User user = new User();
user.setName("caterpillar");
user.setAge(30);
userDAO.insert(user);
user = userDAO.find(new Integer(1));
System.out.println("name: " + user.getName()+"----"+user.getAge()+"----"+user.getId());
}
}
到此爲止,如有不正確的地方,還請高手賜教,再次謝過!!!
一個簡單的Hibernate例子的心得
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章
用MyEclipse創建Hibernate多對一映射
qiudawei115
2020-07-02 19:39:49
關於Hibernate的一些基礎問題
qiudawei115
2020-02-20 23:11:27
用MyEclipse創建Hibernate多對一映射
qiudawei115
2020-07-02 19:39:49
關於Hibernate的一些基礎問題
qiudawei115
2020-02-20 23:11:27