hibernate入门之环境准备,以及第一个例子。

xiaoxiao2021-02-28  107

什么是hibernate?

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

我的理解

JDBC我们都知道,它可以灵活的操作数据库,完成持久层的工作。但随着使用的增多,会越发觉得不舒服或者别扭。因为java是面向对象的解释性语言,我们已经习惯了面向对象的编程,但是在操作数据库时,却要写面向关系的sql语句,而且将类中的数据存入数据库时,我们需要将变量的值一一取出,然后一一放置到数据库中,从数据库中取出值也是同理。这明显违背了面向对象的思想,按理说我们应该把数据封装成对象,然后将对象存入数据库,取出时返回的也应是对象。这就是JDBC的不足,所以hibernate应运而生。它可以代替我们完成封装对象的过程,也可以代替我们将数据库的数据以对象的方式返回给我们。而使得我们可以随心所欲的使用对象编程思维来操纵数据库。

所以,我们应该如何使用hibernate呢?

首先是资源的下载,没有它们是万万不可的(^ _^)* 1. 在hibernate官网下载hibernate文件 2. 在MySQL官网下载驱动的jar包,当然其他数据库同理。 3. JUnit官网可以根据自己需要,下载JUnit的jar包,方便我们测试。

然后是开发工具上的环境搭建,默认为Ecliplse 1. 将下载的hibernate包解压。 2. 在你的Ecliplse的java项目里,新建lib,将hibernate的lib文件里的required的jar包复制粘贴到java项目里的lib,然后再把MySQL驱动和JUnit包也拷贝到java项目里的lib里。 3. 然后build path java项目里lib里的jar包。 4. 打开hibernate文件夹,project->etc->有两个文件,分别为hibernate.cfg.xml和log4j.properties。将这两个文件拷贝到java项目里的src目录下。 5. 然后新建一个包hibernateDemo,再建一个类Student,定义三个属性id,name,age,并且生成get和set方法. 6. 打开hibernate.cfg.xml文件,将如下代码拷贝进去,这是自己的数据库相关的配置文件,具体参数可以查文档,Mysql的代码如下:

<hibernate-configuration> <session-factory> <!-- Database connection settings --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://localhost/hibernate</property> <!-- 你的登录名和密码 --> <property name="connection.username">root</property> <property name="connection.password">root</property> <!-- JDBC connection pool (use the built-in) --> <property name="connection.pool_size">1</property> <!-- SQL dialect --> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- Enable Hibernate's automatic session context management --> <property name="current_session_context_class">thread</property> <!-- Disable the second-level cache --> <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <!-- Echo all executed SQL to stdout --> <property name="show_sql">true</property> <!-- Drop and re-create the database schema on startup --> <property name="hbm2ddl.auto">update</property> <!-- 这个路径先别着急填 --> <mapping resource="hibernateDemo/Student.hbm.xml"/> </session-factory> </hibernate-configuration>

7.然后在hibernateDemo包里面建立一个文件Student.hbm.xml,然后把这个文件的路径配置到刚刚的hibernate.cfg.xml里面 包名/Student.hbm.xml,如果包名含有 . 换做 /,即如果包为hibernate.test.Demo,那么配置的路径就为hibernate/test/Demo/Student.hbm.xml

<mapping resource="hibernateDemo/Student.hbm.xml"/>

8.然后就是往Student.hbm.xml里面写内容了,这里主要是类与数据库表格的映射,我们先建一个表格。打开MySql,代码如下

然后在Student.hbm.xml里写如下代码:

<?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 package="hibernateDemo"> <!-- 写你的表名 如下情况是类名与数据库的表名相同时,不要再写数据库中表的名字,不一样的话额外写下 --> <class name="Student"> <!-- <class name="Student" table="Student"> 后面的也是同理,不再解释--> <!-- 写你的数据库表的主键名 column="id" 可以省略--> <id name="id" column="id"></id> <!-- 写你的其他属性名 column="name" 和column="age" 可省略 --> <property name="name" column="name"></property> <property name="age" column="age"></property> </class> </hibernate-mapping>

以上代码主要是,说明映射关系,即你的Student类与数据库的student表格的关系,所以非常必要。

10.最后的最后建立一个StudentDemo测试类就可以了。配置完成的文件结构如下:

经过一系列复杂的过程,我们终于可以开始编程啦(^_^)

import org.hibernate.cfg.Configuration; import org.hibernate.Session; import org.hibernate.SessionFactory; public class StudentTest { public static void main(String[] args) { Student s =new Student(); s.setId(2); s.setName("w"); s.setAge(23); Configuration cfg = new Configuration(); SessionFactory sf=cfg.configure().buildSessionFactory(); Session session=sf.openSession(); session.beginTransaction(); session.save(s); session.getTransaction().commit(); session.close(); sf.close(); } }

然后控制台就会输出

Hibernate: insert into Student (name, age, id) values (?, ?, ?)

这样就大功告成啦~~~~这时候查看你的数据库中的表,已经被填满信息了哦。

转载请注明原文地址: https://www.6miu.com/read-74286.html

最新回复(0)