最近在学习ssh,现在看到hibernate这块,动手实现了一个简单的demo,对hibernate的功能、使用有了初步了解。 1、首先将Hibernate的jar包复制到Web项目的lib目录下。有些依赖jar包,要额外导入;比如cglib-nodep.jar,不然会报错。 2、配置实体类。这里我用的
最近在学习ssh,现在看到hibernate这块,动手实现了一个简单的demo,对hibernate的功能、使用有了初步了解。
1、首先将Hibernate的jar包复制到Web项目的lib目录下。有些依赖jar包,要额外导入;比如cglib-nodep.jar,不然会报错。
2、配置实体类。这里我用的是一个简单Account类,要注意使用的是javax.persistense.*下面的注解,不是org.hibernate.*下的。
SHOPEX简灰服装商城整站源码下载。 安装方法:1.解压上传程序至网站根目录.. 访问:域名/bak.(用户名:admin 密码:123456)2.进入帝国备份王后,配置数据库数据库信息.选择-www.taomoban.net目录.还原数据库.3.修改FTP目录下的config/config.phpphp 数据库连接信息.4.登陆网站后台--清空缓存..5.删除bak文件夹 后台:shopadm
package com.jobhelp.domain;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity //@Entity表示该类能被hibernate持久化
@Table(name="user") //指定Entity对应的数据表名
public class Account {
@Id //指定该列为主键
@GeneratedValue(strategy=GenerationType.AUTO) //auto为自增长
private Integer id;
@Column(name="name")
private String username;
@Column(name="password")
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
3、在src目录下新建Hibernate的配置文件hibernate.cfg.xml。(MyEclipse向导会自动生成,我用的是Eclipse,就得自己创建了。)
hibernate.cfg.xml的内容如下:
com.mysql.jdbc.Driver jdbc:mysql://localhost/User root 123456 20 true 50 23 false true org.hibernate.dialect.MySQLDialect
4、新建Hibernate工具类,用于获取session。Hibernate中每一个session代表一次完整的数据库操作。
Hibernate官方提供的HibernateUtil.java
package com.jobhelp.util;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
public class HibernateUtil {
private static final SessionFactory sessionFactory;//单例模式的SessionFactory
//static代码块,类加载时初始化hibernate,单例只初始化一次
static{
try{
//从hibernate.cfg.xml中加载配置
//加载@注解配置的实体类用AnnotationConfiguration()
//加载xml配置的实体类使用Configuration()
sessionFactory = new AnnotationConfiguration()
.configure("hibernate.cfg.xml").buildSessionFactory();
} catch (Throwable ex){
System.err.println("Initial SessionFactory Error");
throw new ExceptionInInitializerError(ex);
}
}
public static SessionFactory getSessionFactory(){
return sessionFactory;
}
}
5、初始化MySql数据库,建一个简单的User表即可,我用的表数据如下。
mysql> select * from user; +----+-------+----------+ | id | name | password | +----+-------+----------+ | 1 | admin | 123456 | | 2 | bowen | 123456 | | 3 | tom | 123456 | | 4 | jack | 123456 | +----+-------+----------+
6、执行hibernate程序。Hibernate是ORM框架,与数据库打交道。
Hibernate中session会话与JDBC操作数据库流程差不多。
相对Spring中jdbcTemplate的使用,hibernate不用写sql语句,不用封装结果;逻辑清晰,代码简洁很多,显然有利于提高开发效率。
下面是在一个Test类中,执行了Hibernate程序的代码。
package com.jobhelp.util;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.Transaction;
import com.jobhelp.domain.Account;
public class Test {
public static void main(String[] agrs){
/*Account account =new Account();
account.setUsername("jack");
account.setPassword("123456");*/
//start a hibernate session
Session session = HibernateUtil.getSessionFactory().openSession();
//start a transaction
Transaction transaction = session.beginTransaction();
//insert into database
//session.persist(account);
@SuppressWarnings("all")
//hql query
List list =session.createQuery("from Account").list();
//print query result
for(Account account2: list){
System.out.println(account2.getId()+" : "+account2.getUsername());
}
transaction.commit();
session.close();
}
}
执行结果:
[2014-11-24 21:26:19,083][DEBUG][org.hibernate.jdbc.AbstractBatcher:366] - about to open PreparedStatement (open PreparedStatements: 0, globally: 0) [2014-11-24 21:26:19,083][DEBUG][org.hibernate.SQL:401] - select account0_.id as id0_, account0_.password as password0_, account0_.name as name0_ from user account0_ Hibernate: select account0_.id as id0_, account0_.password as password0_, account0_.name as name0_ from user account0_ ...... [2014-11-24 21:26:19,108][DEBUG][org.hibernate.engine.StatefulPersistenceContext:787] - initializing non-lazy collections 1 : admin 2 : bowen 3 : tom 4 : jack [2014-11-24 21:26:19,109][DEBUG][org.hibernate.transaction.JDBCTransaction:103] - commit ......
注意:Hibernate只会生成表结构,但不会创建数据库。如果指定数据库不存在,hibernate会抛出异常。








