Hibernate入门_增删改查
2024-08-21 01:47:02
一、Hibernate入门案例剖析:
①创建实体类Student 并重写toString方法
public class Student { private Integer sid;
private Integer age;
private String name;
public Integer getSid() {
return sid;
}
public void setSid(Integer sid) {
this.sid = sid;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student [sid=" + sid + ", age=" + age + ", name=" + name + "]";
} }
② 创建学生对象 并赋值
③引入jar包
④ 构建大配置<hibernate.cfg.xml>
可分为以下步骤:
1.连接数据库的语句
2.sql方言
3.可省的配置(show_sql、format_sql 取值为true)
4.让程序生成底层数据表(hbm2ddl.auto) update/create。create是每次将数据表删除后,重新创建
5.关联小配置
<mapping resource="cn/happy/entity/Student.hbm.xml" />
关键代码如下:
<?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> <!-- Database connection settings 数据库连接设置-->
<!-- 驱动类 -->
<property name="connection.driver_class">oracle.jdbc.OracleDriver</property>
<!-- url地址 -->
<property name="connection.url">jdbc:oracle:thin:@localhost:1521:orcl3</property>
<property name="connection.username">wj</property>
<property name="connection.password">9090</property> <!-- SQL dialect (SQL 方言) -->
<property name="dialect">org.hibernate.dialect.Oracle10gDialect</property> <!--在控制台打印后台的SQL语句 -->
<property name="show_sql">true</property> <!-- 格式化显示SQL -->
<!-- <property name="format_sql">true</property> -->
<!-- 自动生成student表 -->
<property name="hbm2ddl.auto">update</property>
<!-- 关联小配置 -->
<mapping resource="cn/happy/entity/Student.hbm.xml" />
<!-- <mapping class="cn.happy.entity.Grade"/> --> </session-factory> </hibernate-configuration>
⑤ 构建小配置(Student.hbm.xml)
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.happy.entity">
<class name="Student" table="STUDENT">
<id name="sid" column="SID">
<!-- 主键生成策略:native:
native:如果后台是Oracle
后台是MySQL,自动应用自增 assigned:程序员给主键赋值
uuid:32位的16进制数
sequence
native --> <generator class="assigned">
<param name="sequence">SEQ_NUM</param>
</generator>
</id>
<!-- <version name="version"></version> -->
<property name="name" type="string" column="NAME"/>
<property name="age"/>
</class>
</hibernate-mapping>
⑥ 工具类HibernateUtil、构建私有静态的Configuration、SessionFactory对象、定义返回session以及关闭session的方法
private static Configuration cf=new Configuration().configure();
private static SessionFactory sf=cf.buildSessionFactory(); //方法返回session
public static Session getSession(){
return sf.openSession();
} //关闭Session public static void CloseSession(){
getSession().close();
}
复制代码
⑦测试类【增删改查】 使用标记After、Before可简化代码
package cn.happy.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; import org.junit.After;
import org.junit.Before;
import org.junit.Test; import cn.happy.entity.Student;
import cn.happy.util.HibernateUtil; public class Test1 {
Session session;
Transaction tx; @After
public void afterTest(){
tx.commit();
HibernateUtil.CloseSession();
} @Before
public void initData(){
session=HibernateUtil.getSession();
tx=session.beginTransaction();
} /*
* get方法查询
*/
@Test
public void getData(){
Student stu=(Student)session.get(Student.class, 3);
System.out.println(stu);
}
/*
* 增加
*/ @Test
public void addData(){
Student stu=new Student();
stu.setSid(12);
stu.setAge(11);
stu.setName("李小龙1");
//读取大配置文件 获取连接信息
Configuration cfg=new Configuration().configure(); //创建SessionFactory
SessionFactory fa=cfg.buildSessionFactory();
//加工Session
Session se=fa.openSession();
Transaction tx = se.beginTransaction();
//保存
se.save(stu);
//事务提交
tx.commit();
se.close(); System.out.println("Save ok!");
} /*
* 删除
*/
@Test
public void delData(){
Session session=HibernateUtil.getSession();
Student stu=new Student();
stu.setSid(2);
Transaction tx=session.beginTransaction();
session.delete(stu);
tx.commit();
HibernateUtil.CloseSession();
System.out.println("del ok!");
} /*
* 修改
*/
@Test
public void updateData(){
Session session=HibernateUtil.getSession();
Student stu=(Student)session.load(Student.class,3);
stu.setName("呵呵");
Transaction tx=session.beginTransaction();
session.update(stu);
tx.commit();
HibernateUtil.CloseSession();
System.out.println("update ok!");
}
}
最新文章
- erlang 故障排查工具
- phpMyAdmin上传文件大小限制
- 未能正确加载“RoslynPackage”包
- [AJAX系列]XMLHttpRequest请求
- 命令行方式使用abator.jar生成ibatis相关代码和sql语句xml文件
- java编写二叉树以及前序遍历、中序遍历和后序遍历 .
- Code generated using the T4 templates for Database First
- Android(java)学习笔记262:JNI之工具快速开发步骤
- android使用shape做selector按钮按下和弹起的动画
- (一)Builder(建造者)模式
- 如何利用BI搭建电商数据分析平台
- 转自CSDN-详述 Java 中的别名现象
- XXE攻防
- Cookies 和 Session的区别
- nohup 部署springboot 使用命令
- df -i 100%时处理方法
- Android内存泄漏原因
- 用Collectors对List去重
- 【代码笔记】iOS-Label随字自动变大
- [LeetCode] 627. Swap Salary_Easy tag: SQL
热门文章
- 常用的底层语法(objc_get,class_get,_cmd,objc_msgSend)
- centos运行asp.netcore的正确姿势
- 【AngularJS】通过jsonp与webmethod交互,实现ajax验证
- Spring AOP统一异常处理
- 金融即服务(FaaS),将开启场景化金融新格局
- SQL Server 对XML数据类型的SQL语句总结
- SaltStack应用grains和jinja模板-第四篇
- spring 概念理解
- Oracle18c创建不带C##的用户
- Centos7.5静默安装Oracle18c