一、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!");
} }

Hibernate入门案例 增删改的更多相关文章

  1. Hibernate入门_增删改查

    一.Hibernate入门案例剖析:  ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private ...

  2. MyBatis入门案例 增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

  3. Hibernate入门案例及增删改查

    一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private I ...

  4. Mybatis入门之增删改查

    Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...

  5. 肝 hibernate 配置and增删改查 and 测试

    已经通宵三天撸代码了,现在的我已经养成晚上修仙写代码的节奏了.....最近 刚刚复习到了 hibernate 谈谈 这篇文章就谈谈我对这货的理解吧. 在看这篇文章之前希望你 知道sessionfact ...

  6. Hibernate下的增删改查

    概述: 关系--对象映射的中间件,属于开源ORM框架,是我们业务逻辑层中的调用数据库的中间件 演变: jdbc---hibernater---mybatis hibernate和mybatis区别? ...

  7. MyBatis案例&增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

  8. hibernate的配置, 增删改查

    路径:查找路径 实际上都是查找编译后的对应的路径,在bin文件夹中总 增删改必须开启事务才行 hibernate加载文件的两种方式 configure 1.引包 antlr-2.7.6.jar bac ...

  9. hibernate搭建及其增删改查

    一.jar包 最基础的hibernatejar包,以及数据库驱动的jar包 二.数据库 t_user表 id int 主键 自动增长 name varchar() 三.配置文件 <?xml ve ...

随机推荐

  1. 配置ubuntu虚拟机备忘

    #1配置minicom sudo minicom -s sudo minicom -w #1.配置网络,嵌入机的ip地址 ifconfig eth0 10.5.52.202 #2.挂载文件,把虚拟主机 ...

  2. java入门 第一季4

    1.数组 1).声明数组 数据类型[]数组名; 数据类型 数组名[]; 2).分配空间 数组名=new 数据类型[数组长度]: 3).赋值 score[0]=98: 直接创建一个长度为4的数组 int ...

  3. 如何让ListView的item不可点击

    原文链接:http://blog.csdn.net/zhangfei_jiayou/article/details/6972752 1. 如果是listView的id是使用系统默认的id,如下, 则可 ...

  4. Effective C++ -----条款23:宁以non-member、non-friend替换member函数

    宁可拿non-member non-friend函数替换member函数.这样做可以增加封装性.包裹弹性(packaging flexibility)和机能扩充性.

  5. NSOJ A fairy tale of the two(最小费用最大流、SPFA版本、ZKW版本)

    n,m<=20,给两个n×m布尔矩阵,每次操作可将第一个矩阵的2个相邻元素互换.输出最少操作次数使得两个矩阵完全一样. 比赛的时候想过按照二分图完美匹配的类似做法构图,不过想到边太多以及卡各种题 ...

  6. js正则匹配以固定格式结尾的字符串并匹配是手机访问,则跳转

    <script> //var pcUrl = "http://res.meadin.com/HotelData/98986_1.shtml"; var pcUrl = ...

  7. webApp路由控制-vue-router2.0

    安装 直接下载 / CDN https://unpkg.com/vue-router 中文api: http://router.vuejs.org/zh-cn/index.html

  8. 【Mongodb】3.X 配置身份验证

    配置身份验证详解: 开启认证: 启动MongoDB./mongodb --syslog --fork --port 20000  --auth 1.如果不添加参数:auth,表明用默认的root的权限 ...

  9. Java 配色方案--Dark Flash Builder - by Wilson Silva

    http://eclipsecolorthemes.org/?view=theme&id=1855

  10. Java系列笔记(3) - Java 内存区域和GC机制

    目录 Java垃圾回收概况 Java内存区域 Java对象的访问方式 Java内存分配机制 Java GC机制 垃圾收集器 Java垃圾回收概况 Java GC(Garbage Collection, ...