hibernate 配置--入门操作----实现crud 操作

素颜马尾好姑娘i 2022-08-26 00:44 272阅读 0赞

hibernate 入门操作——实现crud 操作

转自:http://blog.csdn.net/wang9258/article/details/17891971

一hibernate 是什么?

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。

二:核心接口:

Hibernate的核心接口一共有6个,分别为:Session、SessionFactory、Transaction、Query、Criteria和Configuration。这6个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制

session

Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。

SessionFactory

SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。

hibernate 入门学习

一 下载所依赖的jar 包

hibernate 官方网站:
http://hibernate.org/orm/

个人测试的只需引导requerd 下的jar 文件

CenterCenter 1

一: 开发文档的引导使用

Center 2

Center 3

" class="reference-link">Center 4

Center 5

根据以上信息可以写出—连接数据库的配置文件—-此处以 xml 为例

二: 配置文件的书写—为了方便此处命名规范———-hibernate.cfg.xml—存放在src 文件目录下(也可更改)

文件稍加改动

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. <?**xml version=”1.0” encoding=”utf-8”?>**
  2. <!DOCTYPE hibernate-configuration PUBLIC
  3. “-//Hibernate/Hibernate Configuration DTD 3.0//EN”
  4. “http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"**>**
  5. <**hibernate-configuration**>
  6. <**session-factory**>
  7. <**property name=”connection.driver_class”>**
  8. com.mysql.jdbc.Driver
  9. </**property**>
  10. <**property name=”connection.url”>**
  11. jdbc:mysql://localhost:3306/hiber
  12. </**property**>
  13. <**property name=”connection.username”>root</property>**
  14. <**property name=”connection.password”>199358</property>**
  15. <**property name=”show_sql”>true</property>**
  16. <**mapping resource=”www/csdn/net/hiber2/bean/User.hbm.xml”/>**
  17. </**session-factory**>
  18. </**hibernate-configuration**>

三:实体bean

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.bean;
  2. public class User {
  3. private Integer id;
  4. private String name;
  5. private String sex;
  6. private Integer age;
  7. public User() {
  8. super();
  9. // TODO Auto-generated constructor stub
  10. }
  11. public User(Integer id, String name, String sex, Integer age) {
  12. super();
  13. this.id = id;
  14. this.name = name;
  15. this.sex = sex;
  16. this.age = age;
  17. }
  18. public Integer getId() {
  19. return id;
  20. }
  21. public void setId(Integer id) {
  22. this.id = id;
  23. }
  24. public String getName() {
  25. return name;
  26. }
  27. public void setName(String name) {
  28. this.name = name;
  29. }
  30. public String getSex() {
  31. return sex;
  32. }
  33. public void setSex(String sex) {
  34. this.sex = sex;
  35. }
  36. public Integer getAge() {
  37. return age;
  38. }
  39. public void setAge(Integer age) {
  40. this.age = age;
  41. }
  42. @Override
  43. public String toString() {
  44. return “User [id=” + id + “, name=” + name + “, sex=” + sex + “, age=”
    • age + “]“;
  45. }
  46. }

四: 实体bean 的映射文件—-文件名称User.hbm.xml(为规范命名)

[html] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. <?**xml version=”1.0” encoding=”UTF-8”?>**
  2. <!DOCTYPE hibernate-mapping PUBLIC
  3. “-//Hibernate/Hibernate Mapping DTD 3.0//EN”
  4. “http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"**>**
  5. <**hibernate-mapping**>
  6. <**class name=”www.csdn.net.hiber2.bean.User” table=”user” catalog=”hiber”>**
  7. <**id name=”id”>**
  8. <**column name=”id”></column**>
  9. <**generator class=”native”></generator**>
  10. </**id**>
  11. <**property name=”name”>**
  12. <**column name=”name”></column**>
  13. </**property**>
  14. <**property name=”sex”>**
  15. <**column name=”sex”></column**>
  16. </**property**>
  17. <**property name=”age”>**
  18. <**column name=”age”></column**>
  19. </**property**>
  20. </**class**>
  21. </**hibernate-mapping**>

五:接口方法:

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.dao;
  2. import java.util.List;
  3. public interface BaseDao {
  4. T findById(PK id);
  5. void deleteById(PK id)throws Exception;
  6. void delete(T entity)throws Exception;
  7. void deletes(String ids[])throws Exception;
  8. void update(T entity)throws Exception;
  9. void insert(T entity)throws Exception;
  10. List findAll();
  11. }

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.dao;
  2. import www.csdn.net.hiber2.bean.User;
  3. public interface UserDao extends BaseDao {
  4. }

六 : 接口的实现类

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.dao.impl;
  2. import java.util.List;
  3. import org.hibernate.Session;
  4. import org.hibernate.Transaction;
  5. import www.csdn.net.hiber2.bean.User;
  6. import www.csdn.net.hiber2.dao.UserDao;
  7. import www.csdn.net.hiber2.util.HibernateSessionFactory;
  8. public class UserDaoImpl implements UserDao {
  9. @Override
  10. public User findById(Integer id) {
  11. return (User) HibernateSessionFactory.getSession().get(User.class, id);
  12. }
  13. @Override
  14. public void deleteById(Integer id) throws Exception {
  15. Session session=HibernateSessionFactory.getSession();
  16. Transaction ts=session.beginTransaction();
  17. session.delete(findById(id));
  18. ts.commit();
  19. session.close();
  20. }
  21. @Override
  22. public void delete(User entity) throws Exception {
  23. Session session=HibernateSessionFactory.getSession();
  24. Transaction ts=session.beginTransaction();
  25. session.delete(entity);
  26. ts.commit();
  27. session.close();
  28. }
  29. @Override
  30. public void deletes(String[] ids) throws Exception {
  31. // TODO Auto-generated method stub
  32. }
  33. @Override
  34. public void update(User entity) throws Exception {
  35. Session session=HibernateSessionFactory.getSession();
  36. Transaction ts=session.beginTransaction();
  37. session.update(entity);
  38. ts.commit();
  39. session.close();
  40. }
  41. @Override
  42. public void insert(User entity) throws Exception {
  43. Session session=HibernateSessionFactory.getSession();
  44. Transaction ts=session.beginTransaction();
  45. session.save(entity);
  46. ts.commit();
  47. session.close();
  48. }
  49. @Override
  50. public List findAll() {
  51. return HibernateSessionFactory.getSession().createQuery(“from User”).list();
  52. }
  53. }

七:封装的解析xml 文件 获取链接对象等的操作

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.util;
  2. import org.hibernate.Session;
  3. import org.hibernate.SessionFactory;
  4. import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
  5. import org.hibernate.cfg.Configuration;
  6. import org.hibernate.service.ServiceRegistry;
  7. public class HibernateSessionFactory {
  8. static Configuration cfg;
  9. static SessionFactory sessionFactory;
  10. static ServiceRegistry serviceRegistry;
  11. static{
  12. cfg=new Configuration().configure();// hibernate.cfg.xml
  13. // 创建服务注册对象
  14. serviceRegistry =new StandardServiceRegistryBuilder().applySettings(cfg.getProperties()).build();
  15. // 创建sessionFactory 工厂对象
  16. sessionFactory=cfg.buildSessionFactory(serviceRegistry);
  17. }
  18. // 获取session 对象
  19. public static Session getSession(){
  20. return sessionFactory.openSession();
  21. }
  22. }

八: 测试类

[java] view plain copy 在CODE上查看代码片 派生到我的代码片

  1. package www.csdn.net.hiber2.junit;
  2. import java.util.List;
  3. import org.junit.Test;
  4. import www.csdn.net.hiber2.bean.User;
  5. import www.csdn.net.hiber2.dao.UserDao;
  6. import www.csdn.net.hiber2.dao.impl.UserDaoImpl;
  7. import www.csdn.net.hiber2.util.HibernateSessionFactory;
  8. public class UserTest {
  9. private UserDao userDao=new UserDaoImpl();
  10. @Test
  11. public void test(){
  12. System.out.println(HibernateSessionFactory.getSession());
  13. }
  14. @Test
  15. public void insert() throws Exception{
  16. User entity=new User(null, “chong”, “M”, 19);
  17. userDao.insert(entity);
  18. }
  19. @Test
  20. public void findAll() throws Exception{
  21. List entities=userDao.findAll();
  22. for (User user : entities) {
  23. System.out.println(user.toString());
  24. }
  25. }
  26. }

九: 查询所有的成功效果:

Center 6

发表评论

表情:
评论列表 (有 0 条评论,272人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Mybatis实现CRUD操作

    项目实现的功能 查询所有用户信息 通过Id查询用户信息 添加用户(回显主键) 修改用户信息 删除用户信息 通过用户名字模糊查询 一、引入依赖和工程