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 属性来修改 ...
随机推荐
- automate sap遇上的一些问题
1. get column name of SAPGuiTable columnCount = SAPGuiSession("Session").SAPGuiWindow(&quo ...
- DB2实例
实例是逻辑数据库管理环境,可以在此环境中对数据库进行编目和设置配置参数.根据需要, 可以在一台服务器上创建多个实例,该服务器为每个实例提供唯一的数据库服务器环境. 默认实例:DB2 显示实例: ...
- css-目标伪类选择器:target的应用
目标伪类选择器:target是众多CSS3众多 动态 伪类选择器中的一个,用来匹配锚点指向的元素,突出显示活动的HTML锚. <style> p:target{ border: 2px s ...
- elasticsearch 父子关系
ElasticSearch 中的Parent-Child关系和nested模型是相似的, 两个都可以用于复杂的数据结构中,区别是 nested 类型的文档是把所有的实体聚合到一个文档中而Parent- ...
- 转:谈谈Linux下动态库查找路径的问题
http://blog.chinaunix.net/uid-23069658-id-4028681.html 学习到了一个阶段之后,就需要不断的总结.沉淀.清零,然后才能继续“上路”.回想起自己当年刚 ...
- shell 中cut
和awk差不多的功能 上面的例子中,把 root:x:0:0:root:/root:/bin/bash 重定向到cut命令里,-d表示分隔符,这里使用冒号: 作为分隔符,-f 表示字段,选择了第1,和 ...
- ubuntu下oracle 数据库安装
环境:腾讯云 一. 由于腾讯云直接下载oracle太慢,先安装docker 1.sudo apt update 2.接下来,使用apt安装一些允许通过HTTPS才能使用的软件包: sudo apt i ...
- Electron-vue实战(一)—搭建项目与安装Element UI
Electron-vue实战—搭建项目与安装Element UI 作者:狐狸家的鱼 本文链接 GitHub:sueRimn 一.新建项目1.初始化项目打开cmd,新建一个项目,我使用的是electro ...
- Mybatis基于接口注解配置SQL映射器(一)
上文已经讲解了基于XML配置的SQL映射器,在XML配置的基础上MyBatis提供了简单的Java注解,使得我们可以不配置XML格式的Mapper文件,也能方便的编写简单的数据库操作代码. Mybat ...
- ZROI week2
\[ZROI week2\] 除草机 首先考虑最少的拐点肯定是那种螺旋形状的,然后手玩几个数据发现和列数(行数)有关,且每增加1就是上一个状态加2,直接\(O(1)\)公式即可 吐槽:为啥\(n,m\ ...