Hibernate入门(1)——环境搭建
什么是Hibernate?为什么使用Hibernate?Hibernate有什么优缺点?网上很多大神的文章又详细又通俗易懂。
步骤:
1、创建数据库表格。
2、编写JavaBean实体类。
3、下载Hibernate用到的的Jar包。
4、创建Web工程。
5、导入需要的Jar包(我们下载的可能有些是不需要的,只要导入用到的jar包就行)。
6、创建类与表结构的映射(javabean实体类中属性和相应表格的列的映射)。
7、编写Hibernate配置文件。
8、编写测试类。
具体实现:
1、创建数据表格
为了方便,我们之创建一个简单的表格用于测试就行了。
表格名字叫 user,里面有四列 id,username,pwd ,cellphone
SQL代码
//创建数据库 CREATE DATABASE Hib_test; //创建数据表格 CREATE TABLE user( id INT, username ), pwd ), cellphone ) )
输出结果:
注释
使用的数据库是MySql,使用的界面操作工具是SQLyog
2、编写JavaBean实体类。
我们写一个个JavaBean的实体类。
JAVA代码
package com.hibernate.test; public class User { private int id; private String username; private String pwd; private String cellphone; 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 getPwd() { return pwd; } public void setPwd(String password) { this.pwd = password; } public String getCellphone() { return cellphone; } public void setCellphone(String cellphone) { this.cellphone = cellphone; } }
3、下载Hibernate用到的的Jar包。
下载地址:http://sourceforge.net/projects/hibernate/files/hibernate-orm/5.0.7.Final/hibernate-release-5.0.7.Final.zip/download
下载下来,解压后的目录为:
lib文件夹里面是框架所包含的jar包
project文件里面是项目案例
document文件夹是教程以及API等
4、创建Web工程。
创了个叫HibernateDemo的Web项目。
5、导入需要的Jar包
a、Hibernate需要的核心包,就是解压出来的目录(hibernate-release-5.0.7.Final\lib\required)下的所有jar包。
b、导入数据库驱动包,我用的的是MySql所以导入MySql的依赖包,这个jar包需要网上下载,网上有很多。
将下面的这些jar包复制到项目里的WebContent/WEB-INF/lib目录下面
6、创建类与表结构的映射文件
创建表结构的映射就是一个xml文件,他可以告诉Hibernate哪个数据表和哪个JavaBean类相关联的。
这个表结构映射的xml文件有一定要要求或者说是规范吧:
a、命名规范,一般是:类的名字.hbm.xml
在上面的例子中就是:User.hbm.xml。
b、存放位置:一般把则个文件与他的Java类放在一起。
映射文件:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <!--类名为User,表名也为User--> <class name="com.hibernate.test.User" table="user"> <!--主键映射,属性名为id,列名也为id--> <id name="id" column="id"> <!--下面这个属性的作用是:根据所使用的数据库主键自动增长,这里使用的int类型的数据--> <generator class="native"/> </id> <!--非主键映射,属性和列名一一对应--> <property name="username" column="username"/> <property name="cellphone" column="cellphone"/> <property name="pwd" column="pwd"/> </class> </hibernate-mapping>
注释
映射文件模板大多都一样的,可以在下载的案例中找到一个模板,然后做写修改就行。详细的属性之后再详细讨论。
<hibernate-mapping> <class name="com.hibernate.test.User" table="user"> <id name="java类属性" column="数据表主键"> <generator class="native"/> </id> <property name="java类属性" column="数据表格列名"/> </class> </hibernate-mapping>
7、编写Hibernate配置文件
跟上面的映射文件一样,这个核心配置文件也是一个xml文件,你可以在(hibernate-release-5.0.7.Final\project\etc)目录下找到这个文件的模板。然后做一些修改,应用到自己的项目里。
还是跟上面的映射文件一样,这里的文件也有一定的要求:
a、文件名为:hibernate.cfg.xml (这里的cfg是configure的缩写?)
b、文件放在src目录下。
配置文件的属性:
a、必须配置:数据库链接配置
<property name="hibernate.connection.driver_class">数据库驱动</property>
<property name="hibernate.connection.url">数据库链接url</property>
<property name="hibernate.connection.username">数据库用户名</property>
<property name="hibernate.connection.password">数据库密码</property>
b、必须配置:数据库方言,用来生成适应不同数据库sql语句的配置。
<property name="hibernate.dialect"></property>
c、必须配置:引入配置文件的配置
<mapping resource="映射文件的路径,格式是:包名.配置文件名"/>
d、可选配置:用于把Hibernate生成的sql语句输出到控制台的配置,为了调试方便我们可以用这些配置查看Hibernate对数据库执行了哪些sql语句等等。
<!-- 显示hibernate在运行时候执行的sql语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql -->
<property name="hibernate.format_sql">true</property>
<!-- 自动建表 -->
<property name="hibernate.hbm2ddl.auto">create</property>
Hibernate配置文件的具体修改后的样子:
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <!-- 通常,一个session-factory节点代表一个数据库 --> <session-factory> <!-- 1. 数据库连接配置 --> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql:///Hib_test</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">123456</property> <!-- 数据库方法配置, hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql --> <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property> <!-- 2. 其他相关配置 --> <!-- 2.1 显示hibernate在运行时候执行的sql语句 --> <property name="hibernate.show_sql">true</property> <!-- 2.2 格式化sql --> <property name="hibernate.format_sql">true</property> <!-- 2.3 自动建表 --> <property name="hibernate.hbm2ddl.auto">create</property> <!--3. 加载所有映射--> <mapping resource="com/hibernate/test/User.hbm.xml"/> </session-factory> </hibernate-configuration>
8、编写测试类。
测试类代码 package com.app.test;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; import com.hibernate.test.User; public class App { public static void main(String[] args) { //新New一个User对象,然后设置其的值 User user=new User(); user.setPwd("123456"); user.setUsername("Eastry"); user.setId(333); user.setCellphone("1234567"); //加载配置文件,默认加载的是src目录下的hibernate.cfg,xml文件,当然也可以给一个加载的路径,这样的话配置文件就不一定要放在src目录下面了 Configuration configuration=new Configuration(); configuration.configure(); //创建Session工厂,用来获取Session对象 SessionFactory factory=configuration.buildSessionFactory(); Session session=factory.openSession(); //开启事务 Transaction transaction=session.getTransaction(); transaction.begin(); //保存操作 session.save(user); //提交事务 transaction.commit(); //释放资源 session.close(); System.out.println("successful!"); } }
输出:
上面我尝试了保存一个javaBean对象到数据库里。
Hibernate还 可以读取数据库的数据把数据映射到一个JavaBean对象上面。
之后再讨论。
最新文章
- POJ1753 Flip Game(bfs、枚举)
- javascript高级程序设计---Event对象二
- vyos (三) HA
- Eclipse快捷键 10个最有用的快捷键【转】
- TEA加密
- Sails.js中文文档
- umount: /home: device is busy
- CentOS环境搭建(JDK安装、mysql安装、hadoop安装等)
- 整理JRE瘦身或精简JRE
- sublime使用总结
- ASP.NET Core 2.0 : 五.服务是如何加载并运行的, Kestrel、配置与环境
- Java基础11-List;Set;Map
- Docker inspect - format格式化输出 - 运维笔记
- 064 UDF
- Android资源相关语法
- WebSocket教程(二)
- 理解C++类的继承方式(小白)
- The configuration section &#39;system.serviceModel&#39; cannot be read because it is missing a section decla
- WP集成七牛云存储(原创)
- mac上的webStorm上配置gitHub