Hibernate的xml方法配置和操作代码
一、gradle中包:
compile group: 'org.hibernate', name: 'hibernate-core', version: '5.2.12.Final'
compile group: 'mysql', name: 'mysql-connector-java', version: '5.1.40'
二、项目中导入hibernate
1、向gradle配置文件中引入一中的两个包
2、点击按钮,在facets中添加hibernate,
这时,右下角会出现一个持久化选项卡,点击该选项卡:右键点击B7_main选项,
点击Generate Persisitence Mapping,点击By Database Schema,
(需要自己新建一个po层),选择自己需要的数据库,表以及关系,然后ok即可
它会自动生成一个hibernate.cfg.xml的配置文件,将其拖入resources目录下即可
<?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>
<property name="connection.url"><![CDATA[jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8]]></property>
<property name="show_sql">true</property>
<property name="format_sql">true</property>
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username"></property>
<property name="connection.password"></property>
<mapping resource="User.hbm.xml"/>
<!-- DB schema will be updated if needed -->
<!-- <property name="hbm2ddl.auto">update</property> -->
</session-factory>
</hibernate-configuration>
其中mapping标签必须放在property标签下,不能混着放,每次更新gradle后记得要重新配置数据库的链接密码。
还会自动关系映射出一个和user表对应的类:User(存放于po层)
package com.weikun.po; /**
* Created by Administrator on 2018/3/25.
*/
public class User {
private int id;
private String username;
private String password; 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 getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} @Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false; User user = (User) o; if (id != user.id) return false;
if (username != null ? !username.equals(user.username) : user.username != null) return false;
if (password != null ? !password.equals(user.password) : user.password != null) return false; return true;
} @Override
public int hashCode() {
int result = id;
result = 31 * result + (username != null ? username.hashCode() : 0);
result = 31 * result + (password != null ? password.hashCode() : 0);
return result;
}
}
之后就可以在dao层通过控制User类下的属性方法来映射操控底层数据库的数据了。
还会自动生成和映射到user表的配置文件user.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>
<class name="com.weikun.po.User" table="user" schema="test">
<id name="id">
<column name="id" sql-type="int(11)"/>
</id>
<property name="username">
<column name="username" sql-type="varchar(200)" length="200"/>
</property>
<property name="password">
<column name="password" sql-type="varchar(20)" length="20"/>
</property>
</class>
</hibernate-mapping>
其中<id>标签是指主键,如果用注解的话是@id来标注主键。
联合主键的配置文件代码如下:
<composite-id>
<key-property name="username">
<column name="username" sql-type="varchar(10)" length="10"/>
</key-property>
<key-property name="sex">
<column name="sex" sql-type="varchar(10)" length="10"/>
</key-property>
</composite-id>
三、dao层的操作代码
package com.weikun.dao; import com.weikun.po.User;
import com.weikun.po.User5;
import com.weikun.po.User5PK;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test; import java.util.List; /**
* Created by Administrator on 2018/3/25.
*/
public class UserDAOImpl {
private Configuration configuration=null;
private SessionFactory sessionFactory=null; public UserDAOImpl(){
configuration=new Configuration().configure("hibernate.cfg.xml");//1、将配置文件加载到配置类的对象中 sessionFactory=configuration.buildSessionFactory();//2、使用配置对象创建对话工厂 }
@Test
public void queryByAll(){ Session session=null;
session=sessionFactory.openSession();//3、使用对话工厂打开会话
List<User> list=session.createQuery("from User ").list();//sql--H QL4、执行回话的具体行为
list.forEach(user->System.out.printf("%s-%s\n",user.getUsername(),user.getPassword())); session.close();//5、关闭会话
} @Test
public void queryById(){
Session session=null;
session=sessionFactory.openSession();
User user=session.get(User.class,288);//get
System.out.printf("%s-%s",user.getUsername(),user.getPassword());
session.close(); }
@Test
public void update(){
Session session=null;
session=sessionFactory.openSession();
Transaction transaction=session.beginTransaction();
User user=new User();
user.setId(285);
user.setUsername("MENG");
user.setPassword("8888");
try{
session.update(user);
transaction.commit();
}catch(Exception e){
transaction.rollback();
e.printStackTrace();
}
session.close(); }
@Test
public void del(){
Session session=null;
session=sessionFactory.openSession();
Transaction transaction=session.beginTransaction();
User user=new User();
user.setId(286);
try{
session.delete(user);
transaction.commit();
}catch(Exception e){
transaction.rollback();
e.printStackTrace();
}
session.close();
}
@Test
public void add5(){
Session session=null;
session=sessionFactory.openSession();
Transaction transaction=session.beginTransaction();
User5 user5=new User5();
user5.setUsername("rose1");
user5.setSex("f");
user5.setAge(199);
try{
session.save(user5);
transaction.commit();
}catch(Exception e){
transaction.rollback();
e.printStackTrace();
} session.close();
}
@Test
public void add(){
Session session=null;
session=sessionFactory.openSession();
Transaction transaction=session.beginTransaction();
User user=new User();
user.setPassword("yu");
user.setUsername("YUYUYU");
try{
session.save(user); transaction.commit();
}catch(Exception e){
transaction.rollback();
e.printStackTrace();
} session.close(); }
}
先创建一个配置文件Configuration
private Configuration configuration=null;
再创建一个SessionFactory工厂
private SessionFactory sessionFactory=null;
public UserDAOImpl(){
configuration=new Configuration().configure("hibernate.cfg.xml");//1、将配置文件加载到配置类的对象中 sessionFactory=configuration.buildSessionFactory();//2、使用配置对象创建对话工厂 }
在构造器中实例化配置对象,创建对话工厂。
使用sessionFactory开一个回话session
除了查询以外,其他的增删改都需要使用事务管理,使用session开始一个事务
session=sessionFactory.openSession();
Transaction transaction=session.beginTransaction();
需要做一个trycatch,try中处理事务,catch中进行事务回滚,最后关闭事务
try{
session.save(user); transaction.commit();
}catch(Exception e){
transaction.rollback();
e.printStackTrace();
} session.close();
Hibernate的xml方法配置和操作代码的更多相关文章
- 转:HIBERNATE一些_方法_@注解_代码示例---写的非常好
HIBERNATE一些_方法_@注解_代码示例操作数据库7步骤 : 1 创建一个SessionFactory对象 2 创建Session对象 3 开启事务Transaction : hibernate ...
- Hibernate 注解时 hibernate.hbm.xml的配置方法 以及与SSH整合里的配置方式
①纯Hibernate开发: 当你在Bean中写入注解后,需要告诉hibernate哪些类使用了注解. 方法是在hibernate.hbm.xml文件中配置 <!DOCTYPE hibernat ...
- Spring整合Hibernate的XML文件配置,以及web.xml文件配置
利用Spring整合Hibernate时的XML文件配置 applicationContext.xml <?xml version="1.0" encoding=" ...
- hibernate.hbm.xml文件配置入门小结(1)
在Hibernate中,各表的映射文件xxx.hbm.xml可以通过工具生成,例如在使用MyEclipse开发时,它提供了自动生成映射文件的工具. hibernate.hbm.xml文件的基本结构如下 ...
- hibernate.cfg.xml常见配置
转载自:http://blog.csdn.net/qiaqia609/article/details/9456489 <!--标准的XML文件的起始行,version='1.0'表明XML的版本 ...
- hibernate4中使用Session doWork()方法进行jdbc操作(代码)
Hibernate3.3.2版本中getSession().connection()已被弃用,hibernate4中官方推荐使用Session doWork()方法进行jdbc操作 首先看看Work接 ...
- hibernate4.3.5,Final hibernate.cfg.xml的配置
今天是接触hibernate的第二天,用来练习的是hibernate最新的版本hibernate-release-4.3.5.Final 要使用hibernate,则先要引入它的jar包,要引入的ja ...
- Hibernate框架 主配置文件 Hibernate.cfg.xml 映射配置 说明
1 主配置文件 Hibernate.cfg.xml 主配置文件中主要配置:数据库连接信息.其他参数.映射信息! 常用配置查看源码: hibernate-distribution-3.6.0.Final ...
- 【Hibernate学习笔记-4】在hibernate.cfg.xml中配置C3P0数据源
jar包 hibernate.cfg.xml <?xml version="1.0" encoding="GBK"?> <!DOCTYPE h ...
随机推荐
- iOS库--.a与.framework
一.什么是库? 库是共享程序代码的方式,一般分为静态库和动态库. 二.静态库与动态库的差别? 静态库:链接时完整地拷贝至可运行文件里.被多次使用就有多份冗余拷贝. 动态库:链接时不复制.程序执行时由系 ...
- 观光奶牛Sightseeing Cows (二分+spfa(dfs))
观光奶牛 农夫约翰已决定通过带他们参观大城市来奖励他们的辛苦工作!奶牛必须决定如何最好地度过他们的空闲时间. 幸运的是,他们有一个详细的城市地图,显示L(2≤L≤1000)主要地标(方便编号为1 .. ...
- 编写高质量的Makefile
源地址 :http://blog.csdn.net/maopig/article/details/6801749 一.前言 回想自己的第一个Makefile,是这个样子的 CODE hello:hel ...
- 通过obs进行推流
我们除了通过ffmpeg进行推流外还可以使用OBS这个软件进行推流, 界面化工具,配置起来也方便 obs下载地址 obs的基本配置使用教程 这里需要注意的是在填写推流地址URL 的时候 有一个流秘钥 ...
- Oracle自制事务
数据库事务是一种单元操作,要么全部操作成功,要么全部失败.在Oracle中,一个事务是从执行第一个数据操作语言(DML)语句开始的,直到执行一个COMMIT语句,提交保存事务,或执行一个ROLLBAC ...
- Console.WriteLine 不会输出到unity控制台
1,Console.WriteLine() 是输出到控制台程序(console application)的命令 2,Unity中控制台是一个独立的程序,要想输出到Unity控制台需要使用Debug.L ...
- ZBrush通过绘制层得到子物体
本文将为大家介绍在ZBrush® 软件中第三种创建子物体的方法,即使用绘制层得到子物体. 1.在Light Box(灯光盒子)默认的3D工具中选择SuperAverageMan_low人体模型,在视图 ...
- Python 进行网络编程
Date: 2019-06-10 Author: Sun 1. Python TCP通信实现 socket()函数 Python 中,我们用 socket()函数来创建套接字,语法格式如下: sock ...
- H5-移动端适配
之前写H5页面也会遇到适配问题, 是通过媒体查询一点一点调整,始终觉得很繁琐,但一直也没去想想解决的办法. 今天专门花了一上午的时间来去研究. 小生只是刚踏入前端路的小白,对于网上各位大佬的讲解适配 ...
- Layui表格编辑【不依赖Layui的动态table加载】
依赖jquer,layui/css <td class="My_edit"></td> Jquery代码 //-----[Layui表格编辑(<td ...