Hibernate的基本功能:对数据库的增删改查(创建对象实例)
一、通过实例化的对象向数据库添加新记录
package com.yh.test; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test; import com.yh.entity.Buyer; public class Demo { @Test
public void doAdd() {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();
Buyer buyer = new Buyer();
buyer.setUsername("yehuan");
buyer.setPassword("123");
session.save(buyer);
transaction.commit();
session.close();
sessionFactory.close();
}
}
二、通过实例化的对象更新数据库中对应的记录
代码与添加类似,仅将save()方法改成update()方法,更新时以主键映射的属性为条件。
注:saveOrUpdate()方法两者都适用。
三、通过实例化的对象删除数据库中对应的记录
代码与添加类似,仅将save()方法改成delete()方法,删除时以主键对应属性为条件。
四、查询数据库中的记录
1.根据主键对应属性查询(可用于实例化单个对象)
通过get()和load()方法。
区别:
get()方法会直接创建实际对象,查找不到则抛出异常NullPointerException。
load()方法会返回一个代理对象,里面只保存了主键对应属性的值,其他属性只在用的时候再向数据库查询,查找不到则抛出异常ObjectNotFoundException。
@Test
public void doSingleQuery() {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Buyer buyer = session.load(Buyer.class,"yehuan1");
System.out.println(buyer.getPassword());
session.close();
sessionFactory.close();
}
2.根据其他属性查询(可用于实例化多个对象)
@Test
public void doSimpleSingleQuery() {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();
Criteria criteria = session.createCriteria(Buyer.class);
criteria.add(Restrictions.eq("username", "yehuan1"));
@SuppressWarnings("unchecked")
List<Buyer> list = criteria.list();
for(Buyer b:list){
System.out.println(b); // 调用Buyer类中的toString()方法
}
transaction.commit();
session.close();
sessionFactory.close();
}
3.查询类对应表的所有记录(可用于实例化多个对象)
通过createQuery()和createSQLQuery()方法。
区别:
createQuery()用的hql语句进行查询,以hibernate生成的Bean为对象装入list返回。
createSQLQuery()用sql语句查询,以对象数组进行存储,通过addEntity()方法可将返回结果改成和createQuery()一样。
@Test
public void doAllQuery() {
SessionFactory sessionFactory = new Configuration().configure().buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();
String hql="from Buyer";
Query query = session.createQuery(hql);
@SuppressWarnings("unchecked")
List<Buyer> list = query.list();
for(Buyer b:list){
System.out.println(b); // 调用Buyer类中的toString()方法
}
transaction.commit();
session.close();
sessionFactory.close();
}
Hibernate的基本功能:对数据库的增删改查(创建对象实例)的更多相关文章
- XML为数据库进行增删改查(实例)
//增删改查文件 package xml2; import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.Fi ...
- 利用Hibernate 框架,实现对数据库的增删改查
增: package com.maya.test; import org.hibernate.*; import org.hibernate.cfg.*; import com.maya.model. ...
- java jdbc 连接mysql数据库 实现增删改查
好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...
- 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页
使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ...
- ThinkPHP实现对数据库的增删改查
好久都没有更新博客了,之前老师布置的任务总算是现在可以说告一段落了,今天趁老师还没提出其他要求来更新一篇博客. 今天我想记录的是我之前做项目,自己所理解的ThinkPHP对数据库的增删改查. 首先要说 ...
- 【转载】通过JDBC对MySQL数据库的增删改查
通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...
- Java通过JDBC连接数据库的三种方式!!!并对数据库实现增删改查
前言 java连接数据库完整流程为: 1,获得驱动(driver),数据库连接(url),用户名(username),密码(password)基本信息的三种方式. 2,通过获得的信息完成JDBC实现连 ...
- Hibernate第一个程序(最基础的增删改查) --Hibernate
本例实现Hibernate的第一个程序,Hibernate的优点我想大家都很清楚,在这里不做过多赘述.总之,使用Hibernate对数据库操作,也就是来操作实体对象的! 项目目录: 一.第一步要做的就 ...
- 9.5Django操作数据库的增删改查
2018-9-5 18:10:52 先贴上笔记 day61 2018-04-28 1. 内容回顾 1. HTTP协议消息的格式: 1. 请求(request) 请求方法 路径 HTTP/1.1\r\n ...
- Java操作数据库实现"增删改查"
本文主要讲解JDBC操作数据库 主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一 DriverManager类 DriverManage类 ...
随机推荐
- Python基础(slice切片)
l = ['傻狗1','傻狗2','傻狗3','傻狗4','傻狗5','傻狗6'] print(l[0:3])#['傻狗1', '傻狗2', '傻狗3'] numbers = list(range(1 ...
- 跟着老猫来搞GO-容器(1)
前期回顾 前面的一章主要和大家分享了GO语言的函数的定义,以及GO语言中的指针的简单用法,那么本章,老猫就和大家一起来学习一下GO语言中的容器. 数组 数组的定义 说到容器,大家有编程经验的肯定第一个 ...
- 使用 @Transactional 时常犯的N种错误
@Transactional是我们在用Spring时候几乎逃不掉的一个注解,该注解主要用来声明事务.它的实现原理是通过Spring AOP在注解修饰方法的前后织入事务管理的实现语句,所以开发者只需要通 ...
- 菜鸡的Java笔记 - java 访问控制权限
java中四种访问控制权限的使用 内容 在java里面一共定义有四个权限,按照由小到大的顺序:private<defaule<prote ...
- 【linux系统】java环境搭建
搭建步骤 1.安装java : 上传java安装包到linux系统----- rz jdk-8u202-linux-x64.tar.gz jdk下载地址:https://www.oracle.com/ ...
- 基于Netty4手把手实现一个带注册中心和注解的Dubbo框架
阅读这篇文章之前,建议先阅读和这篇文章关联的内容. 1. 详细剖析分布式微服务架构下网络通信的底层实现原理(图解) 2. (年薪60W的技巧)工作了5年,你真的理解Netty以及为什么要用吗?(深度干 ...
- PAT A1107——并查集
Social Clusters When register on a social network, you are always asked to specify your hobbies in ...
- [hdu4747]Mex
首先计算出以1为左端点的所有区间的mex,考虑删除左端点仍然维护这个序列:设当前删除点下一次出现在y,y~n的mex不变,从左端点到y的点中大于删除值的点要变成删除值,因为这个是不断递增的,所以是一段 ...
- 微信小程序的优点(水一篇)
- 快速的加载 - 更强大的能力 - 原生的体验 - 易用且安全的微信数据开放 - 高效和简单的开发 摘自微信官方文档 https://developers.weixin.qq.com/minipro ...
- Linux检测磁盘空间
在linux中,文件系统将所有的磁盘都并入一个虚拟目录下,在使用新的存储媒体之前,需要把它放到虚拟目录下,这项工作称为挂载. 1.mount命令 mount会输出当前系统上挂载的设备列表,要在虚拟目录 ...