Hibernate之开门见山

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 1:SSH框架:   Struts2:基于mvc模式的应用层框架模式(Servlet层)   Hibernate:基于持久层的框架(数据访问层)   Spring:创建对象对象处理的依赖关系以及框架整合(Service层) 2:框架和之前学的对比MVC分层模式: 搭建Hiberna...

1:SSH框架:

  Struts2:基于mvc模式的应用层框架模式(Servlet层)

  Hibernate:基于持久层的框架(数据访问层)

  Spring:创建对象对象处理的依赖关系以及框架整合(Service层)


2:框架和之前学的对比MVC分层模式:


搭建Hibernate环境,开发步骤:

  1:下载源码

    Hibernate官网:http://hibernate.org/ 

  2:引入jar包:(9个jar包哦~~~)

    (1)hibernate3.jar:Hibernate核心jar包文件;

    (2)lib目录下面的required目录里面的6个包

       antlr-2.7.6.jar;

       commons-collections-3.1.jar;

       dom4j-1.6.1.jar;

       javassist-3.12.0.GA.jar;

                  jta-1.1.jar;

                  slf4j-api-1.6.1.jar

    (3)lib目录下面的jpa目录里面的1个包

       hibernate-jpa-2.0-api-1.0.0.Final.jar

    (4)最后一个mysql驱动包

  3:写对象以及对象的映射;

    实体类名.java      对象

    实体类名.hbm.xml   对象的映射

  4:Hibernate配置文件:src/hibernate.cfg.xml

    数据连接配置

    加载所有的映射(*.hbm.xml)


实例演示Hibernate之Hello world!!!

1:第一步:肯定引入jar包咯,毕竟是框架吗!所以引入上面的9个jar包哦~~~

2:第二步:肯定是创建数据库和数据表了,毕竟Hibernate是替换之前学的数据交互层了。

  创建user数据表:

3:第三步:写对象和对象的映射

  3.1:首先创建一个实体类哦~~~,如下所示:

 1 package com.bie.po;
 2 /** 
 3 * @author BieHongLi 
 4 * @version 创建时间:2017年3月8日 下午5:17:23 
 5 * 
 6 */
 7 public class User {
 8 
 9     private int id;
10     private String name;
11     private String password;
12     private String email;
13     private String phone;
14     public int getId() {
15         return id;
16     }
17     public void setId(int id) {
18         this.id = id;
19     }
20     public String getName() {
21         return name;
22     }
23     public void setName(String name) {
24         this.name = name;
25     }
26     public String getEmail() {
27         return email;
28     }
29     public void setEmail(String email) {
30         this.email = email;
31     }
32     public String getPhone() {
33         return phone;
34     }
35     public void setPhone(String phone) {
36         this.phone = phone;
37     }
38     public String getPassword() {
39         return password;
40     }
41     public void setPassword(String password) {
42         this.password = password;
43     }
44     
45     
46 }

   3.2:创建好实体类之后就配置对象的映射,毕竟这个框架的映射还是很牛逼的。

    创建User.hbm.xml,完成对象和数据表的操作;

     (1):对象与表
         (2):属性与字段的对应
         (3):类型的对应,类型默认采用属性的类型,type不写的话

 1 <?xml version="1.0"?>
 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     
 6 <hibernate-mapping package="com.bie.po"> 
 7     <!-- 操作条件:
 8         1:对象与表
 9         2:属性与字段的对应
10         3:类型的对应,类型默认采用属性的类型,type不写的话
11      -->
12     <class name="User" table="user">
13         <!-- 主键,映射 -->
14         <id name="id" column="id">
15             <generator class="native"></generator>
16         </id>
17         
18         <!-- 非主键,映射 -->
19         <property name="name" column="name"></property>
20         <property name="password" column="password"></property>
21         <property name="email" column="email"></property>
22         <property name="phone" column="phone"></property>
23         
24         
25     </class>
26 
27 </hibernate-mapping>

  实体类.hbm.xml如何找模板???:

    这个文件去下载的Hibernate包里面搜索一个模板,然后复制出来,方便之后使用,操作如下所示:

4:src/hibernate.cfg.xml(寻找的目录如:\hibernate-distribution-3.6.0.Final\project\etc)

  4.1:数据连接配置

  4.2:加载所有的映射(*.hbm.xml)

 1 <!DOCTYPE hibernate-configuration PUBLIC
 2     "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
 3     "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
 4 
 5 <hibernate-configuration>
 6     <session-factory>
 7         <!-- 
 8             1:数据连接配置
 9             2:加载所有的映射(*.hbm.xml)
10          -->
11          
12          <!-- 1:数据连接配置 -->
13          <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
14          <property name="hibernate.connection.url">jdbc:mysql:///test</property>
15          <property name="hibernate.connection.username">root</property>
16          <property name="hibernate.connection.password">123456</property>
17          <!-- mysql数据库的方言 -->
18          <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
19          
20          <property name="hibernate.show_sql">true</property>
21          
22          <!-- 2:加载所有的映射(*.hbm.xml) -->
23          <mapping resource="com/bie/po/User.hbm.xml"/>
24          
25     </session-factory>
26 </hibernate-configuration>

 5:写测试的方法,完成第一个Hibernate程序;

 1 package com.bie.test;
 2 
 3 import org.hibernate.Session;
 4 import org.hibernate.SessionFactory;
 5 import org.hibernate.Transaction;
 6 import org.hibernate.cfg.Configuration;
 7 import org.junit.Test;
 8 
 9 import com.bie.po.User;
10 
11 /** 
12 * @author BieHongLi 
13 * @version 创建时间:2017年3月8日 下午5:28:35 
14 * 
15 */
16 public class HelloTest {
17 
18     @Test
19     public void testHello(){
20         //对象
21         User user=new User();
22         user.setName("张三");
23         user.setPassword("123456");
24         user.setEmail("1748741329@qq.com");
25         user.setPhone("15236083005");
26         
27         //获取加载配置文件的管理类对象
28         Configuration config=new Configuration();
29         //默认加载src/hibernate.cfg.xml文件
30         config.configure();
31         //创建session的工厂文件
32         SessionFactory sf=config.buildSessionFactory();
33         //创建session(代表一个会话,与数据库连接的会话)
34         Session session=sf.openSession();
35         //开启事务
36         Transaction tx=session.beginTransaction();
37         //保存到数据库
38         session.save(user);
39         //提交事务
40         tx.commit();
41         //关闭
42         session.close();
43         //sessionFactory关闭
44         sf.close();
45     
46         
47     }
48 }

<!-- mysql数据库的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

  1》如何获取mysql方言的这句org.hibernate.dialect.MySQLDialect???

    首先按着ctrl+shift+t 然后搜索MySQLDialect如下所示,然后取到下图所示即可;  

趁年轻,我们要敢于拼搏!!!年轻就是资本啊!!!

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
SQL 存储 Oracle
Oracle 面试题及答案整理,最新面试题
Oracle 面试题及答案整理,最新面试题
1195 0
|
前端开发 Java 数据库连接
JavaWeb:登录注册功能实现
JavaWeb 登录注册是一种常见的网站开发功能,使用 Java 编程语言和 Web 技术来实现用户注册和登录功能
478 3
|
机器学习/深度学习 人工智能 自然语言处理
《解码AI大模型涌现能力:从量变到质变的智能跃迁》
人工智能大模型的涌现能力是当今科技的焦点。其产生依赖于四大关键因素:1) 海量数据提供丰富的训练素材,涵盖多样化的文本和图像;2) 强大算力如GPU、TPU加速模型训练,突破性能瓶颈;3) 精妙架构如Transformer引入自注意力机制,提升语义理解;4) 过参数化与优化策略使模型不断进化,展现未曾预设的能力。这些因素协同作用,推动大模型在复杂任务中表现出色,为未来带来更多可能。
943 11
|
安全 数据可视化 数据挖掘
医院定位导航系统:技术革新助力医院安全管理与运营效率双重提升
医疗定位导航系统不仅集成了高精度的定位技术,还融合了人员定位、安全预警等多元化功能,为医院管理、患者就医及医护人员工作提供了全方位的支持。
492 1
医院定位导航系统:技术革新助力医院安全管理与运营效率双重提升
|
存储 Unix 虚拟化
Docker容器简介
Docker是一种轻量级的虚拟化技术,它通过容器化应用,提高了硬件资源利用率,简化了应用的部署、运输和运行,且与虚拟机相比,具有更快的交付速度和更低的资源消耗。
383 3
|
前端开发 安全 API
前端全栈之路Deno篇(三):一次性搞懂和学会用Deno 2.0 的权限系统详解和多种权限配置权限声明方式
本文深入解析了 Deno 2.0 的权限系统,涵盖主包和第三方包的权限控制机制,探讨了通过命令行参数、权限 API 和配置文件等多种权限授予方式,并提供了代码示例和运行指导,帮助开发者有效管理权限,提升应用安全性。
412 0
|
SQL NoSQL Linux
gRPC 基础编码使用手册
gRPC 基础编码使用手册
383 6
|
SQL 数据挖掘 关系型数据库
|
人工智能 搜索推荐 机器人
ai教育
【8月更文挑战第4天】ai教育
806 0
|
前端开发 容器

热门文章

最新文章