Hibernate入门教程(一):入门示例(Myeclipse)
●项目结构

●本项目所用Hibernate版本为5.4.5.Final,导入jar只需lib目录下的required和MySQL所需的jar驱动
1.导入相关jar包(配置构建路径)
说明:本人已将所需的jar包添加到用户库,所以无需建lib目录导入jar包
鼠标在项目名右键,构建路径-->配置构建路径-->添加库-->用户库,选择所需的库
2.创建实体类User.java
package com.sve.Test;
public class User {
private int uid;
private String username;
private String password;
private String address;
public int getUid() {
return uid;
}
public void setUid(int uid) {
this.uid = uid;
}
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;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
User.java
3.创建对象映射User.hbm.xml
一般跟JavaBean对象放在同一目录,后缀为 .hbm.xml
<?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 package="com.sve.Test">
<!--
1.配置类与表对应
class标签
name属性:实体类名
table属性:数据库表名称
-->
<class name="User" table="User"> <!--
2.配置实体类id与表id对应
hibernate要求实体类有一个属性唯一值
hibernate要求表有字段作为唯一值
--> <!--
id标签
name属性:
column属性:
-->
<id name="uid" column="uid">
<!--
设置数据库表id增长策略
native:生成表id值就是主键自动增长
-->
<generator class="native"></generator>
</id> <!--
配置其他属性和表字段对应
name属性:实体类属性名称
column属性:生成表字段名称
-->
<property name="username" column="username"></property>
<property name="password" column="password"></property>
<property name="address" column="address"></property>
</class>
</hibernate-mapping>
User.hbm.xml
4.创建hibernate.cfg.xml
放在src目录下,名字不可改
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<!-- 通常,一个session-factory节点代表一个数据库 -->
<session-factory>
<!-- 第一部分: 配置数据库信息,必须的 -->
<!-- 加载驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 创建链接 serverTimezone=UTC:防止时区问题 -->
<property name="hibernate.connection.url">jdbc:mysql:///hibernate_demo?serverTimezone=UTC</property>
<!-- 数据库用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库用户名密码 -->
<property name="hibernate.connection.password">123456</property> <!-- 第二部分:配置hibernate信息 ,可选的 -->
<!-- 数据库方法配置, hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 显示hibernate在运行时候执行的sql语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql语句 -->
<property name="hibernate.format_sql">true</property>
<!-- update:如果有表,则更新,没有表,则创建 -->
<property name="hibernate.hbm2ddl.auto">create</property> <!-- 第三部分:把映射文件放到核心文件中 ,必须的 -->
<mapping resource="com/sve/Test/User.hbm.xml" />
</session-factory>
</hibernate-configuration>
hibernate.cfg.xml
5.测试
package com.sve.Test; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; public class Test {
public static void main(String[] args) {
User user=new User();
user.setUsername("小小");
user.setPassword("123");
user.setAddress("天坛"); //获取加载配置管理类
Configuration configuration = new Configuration(); //不给参数就默认加载hibernate.cfg.xml文件,
configuration.configure(); //创建Session工厂对象
SessionFactory factory = configuration.buildSessionFactory(); //得到Session对象
Session session = factory.openSession(); //使用Hibernate操作数据库,都要开启事务,得到事务对象
Transaction transaction = session.getTransaction(); //开启事务
transaction.begin(); //把对象添加到数据库中
session.save(user); //提交事务
transaction.commit(); //关闭Session
session.close();
}
}
Test.java
运行成功后,查看相应的数据库的表是否发生改变和控制台是否有相应的语句
配置文件说明:
一.映射配置文件
1.映射配置文件位置和名称没有固定要求
2.id标签和property标签中,column属性可以省略,和name属性值一样(不建议这样做)
3.property标签type属性,设置生成表字段的类型(一般不设置,自动对应类型)
二.核心配置文件
1.核心配置文件位置和名称是固定的
2.数据库部分是必要的,Hibernate部分是可选的,映射文件是必须的
实体类编写规则:
1.实体类属性是私有的
2.私有属性使用公开的的set和get方法操作
3.要求实体类有属性作为唯一值(一般使用id)
4.实体类属性建议不使用基本数据类型,使用基本类型对应的包装类(本示例为简单示例,所以使用基本数据类型)
hibernate主键生成策略

1.native:根据使用的数据库自动选择相应的值
2.uuid:使用uuid生成策略,实体类属性类型 必须 是 字符串类型
本示例参考https://www.cnblogs.com/Java3y/p/8520601.html,在此感谢Java3y
Hibernate入门教程(一):入门示例(Myeclipse)的更多相关文章
- SharePoint 2013 入门教程之入门手册
当我们搭建完环境,创建应用程序和网站集后,就已经正式开启了我们的SharePoint之旅了,进入网站以后,开始基本的使用.设置,了解SharePoint相关特性,下面,来简单了解下SharePoint ...
- SharePoint 2013 入门教程
以下文章是自己在学习SharePoint的过程中,不断积累和总结的博文,现在总结一个目录,分享给大家.这个博客也是自己从SharePoint入门,到一个SharePoint开发的成长记录,里面记录的都 ...
- SharePoint 2013 入门教程--系列文章
转:http://www.cnblogs.com/jianyus/p/3381415.html 以下文章是自己在学习SharePoint的过程中,不断积累和总结的博文,现在总结一个目录,分享给大家.这 ...
- SharePoint 2013 入门教程 [不断更新~]
以下文章是自己在学习SharePoint的过程中,不断积累和总结的博文,现在总结一个目录,分享给大家.这个博客也是自己从SharePoint入门,到一个SharePoint开发的成长记录,里面记录的都 ...
- TensorFlow 中文资源全集,官方网站,安装教程,入门教程,实战项目,学习路径。
Awesome-TensorFlow-Chinese TensorFlow 中文资源全集,学习路径推荐: 官方网站,初步了解. 安装教程,安装之后跑起来. 入门教程,简单的模型学习和运行. 实战项目, ...
- Cognos入门教程
Cognos入门教程 1. ReportStudio入门教程 ReportStudio入门教程(http://blog.csdn.net/column/details/ygy-reportstudio ...
- Vue.js + Webpack + ECMAScript 6 入门教程
Vue.js学习教程 1.Vue.js——60分钟快速入门 2.Vue.js——60分钟组件快速入门(上篇) 3.Vue.js——60分钟组件快速入门(下篇) 4.Vue.js——基于$.ajax实现 ...
- 关于docker入门教程
简介:docker入门教程 docker入门教程翻译自docker官方网站的Docker getting started 教程,官方网站:https://docs.docker.com/linux/s ...
- TensorFlow 中文资源精选,官方网站,安装教程,入门教程,实战项目,学习路径。
Awesome-TensorFlow-Chinese TensorFlow 中文资源全集,学习路径推荐: 官方网站,初步了解. 安装教程,安装之后跑起来. 入门教程,简单的模型学习和运行. 实战项目, ...
- WPF入门教程系列二十三——DataGrid示例(三)
DataGrid的选择模式 默认情况下,DataGrid 的选择模式为“全行选择”,并且可以同时选择多行(如下图所示),我们可以通过SelectionMode 和SelectionUnit 属性来修改 ...
随机推荐
- VB - 错误处理
1.最常见的错误是运行时错误,也就是说错误在脚本正在运行的时候发生,是脚本试图进行非法操作的结果.例如零被作为除数.在vbs中,任何运行时错误都是致命的,此时,脚本将停止运行,并在屏幕上显示一个错误消 ...
- Java实验报告(四)&第六周学习总结
班级 计科二班 学号 20188425 姓名 IM 完成时间2019/10/07 评分等级 一.实验目的 (1)掌握类的继承 (2)变量的继承和覆盖,方法的继承,重载和覆盖的实现: 二.实验的内容 ( ...
- [心得]Ubuntu無法ssh登入
裝好ssh後,發覺無法用root登入,可是sshd_config接正確. 後來發現原因在於,Ubuntu沒有root帳號,但是可以透過sudo -s拿到root權限. su root 密碼怎樣打也行不 ...
- 简述ArcGIS的空间连接(Spatial Join)与字段映射(Field Map)操作
插个广告,制作ArcGIS的Tool工具学习下面的教程就对了:零基础学习Python制作ArcGIS自定义工具 牢骚一下 在使用ArcMap进行空间连接操作的时候,往往会有两种特殊需求,其一是连接重叠 ...
- WPF自适应问题
引用水哥同事的文章 点击跳转
- elasticsearch Mapping 定义索引
Mapping is the process of defining how a document should be mapped to the Search Engine, including i ...
- Codeforces 1179D 树形DP 斜率优化
题意:给你一颗树,你可以在树上添加一条边,问添加一条边之后的简单路径最多有多少条?简单路径是指路径中的点只没有重复. 思路:添加一条边之后,树变成了基环树.容易发现,以基环上的点为根的子树的点中的简单 ...
- Java集合体系结构(List、Set、Collection、Map的区别和联系)
Java集合体系结构(List.Set.Collection.Map的区别和联系) 1.Collection 接口存储一组不唯一,无序的对象 2.List 接口存储一组不唯一,有序(插入顺序)的对象 ...
- Yum与RPM
Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器.基于RPM包管理,能够从指定的服务器自动下载 ...
- 数据结构---Java---Hastable
1.概述 1.1 Hashtable是线程安全的: 1.2 源码 public class Hashtable<K,V> extends Dictionary<K,V> imp ...