Hibernate的增删改查
来源:互联网 发布:怎么复制淘宝主图图片 编辑:程序博客网 时间:2024/04/25 08:08
步骤
(1)搭建Hibernate框架
1-1:导入相应的jar包
1-2:配置hibernate.cfg.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>
<!-- 配置数据库方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 配置数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 配置数据库url -->
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
<!-- 配置用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 配置密码 -->
<property name="hibernate.connection.password">1921</property>
<!-- 是否输出Hibernate生成的SQL语句,开启为true -->
<property name="show_sql">true</property>
<!-- ddl语句自动建表 create时先检查表是否存在,存在,则删除再重新建表;
update当表不存在时,建表,当表存在时,更新表中的数据 -->
<property name="hbm2ddl.auto">update</property>
<!-- 是否对输出SQL进行格式化 -->
<property name="format_sql">true</property>
<!-- 注册ORM实体类映射文件 -->
<mapping resource="com/caokaiyuan/domain/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
(2)创建实体类(JavaBean对象)
package com.caokaiyuan.domain;
public class User
{
private int id;
private String username;
private String password;
public User()
{
}
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;
}
}
(3)创建实体类的配置映射文件,命名规则:类名.hbm.xml(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 package="com.caokaiyuan.domain">
<class name="User" table="user">
<!-- 配置主键映射 -->
<id name="id">
<generator class="increment"/>
</id>
<!-- 配置类中其他属性 -->
<property name="username"/>
<property name="password"/>
</class>
</hibernate-mapping>
笔记:
<!-- 配置主键映射 -->
<id name="id"> name:属性名
column :主键字段名,默认为属性名
<column name="id"></column>
主键生成器
<generator class="increment"/>
</id>
常见的主键生成策略
increment:类似于数据库表中的自增列,往数据库插入一个新的实体对象时,其主键在上一次得基础上加一。
identity:每次插入新的对象时,都会调用数据库本身的identity生成器生成标识符。
sequence:每次插入新的对象时,都会调用数据库的sequence对象产生标识符。
uuid:每次新增对象时,用一个128bit的UUID算法生成长度为32的字符串标识符。
assigned:默认的生成策略,不提供主键的自动生成策略。
(4)使用Hibernate中API进行增删改查操作
4-1:创建SessionFactory工厂工具类
package com.caokaiyuan.util;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
public class SessionFactoryUtil
{
private static SessionFactory sessionFactory;
static
{
try
{
//创建Configuration对象,读取核心配置文件hibernate.cfg.xml
Configuration cfg = new Configuration().configure();
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(cfg.getProperties()).buildServiceRegistry();
sessionFactory = cfg.buildSessionFactory(serviceRegistry);
}
catch (Throwable e)
{
e.printStackTrace();
}
}
//获得SessionFactory工厂对象
public static SessionFactory getSessionFactory()
{
return sessionFactory;
}
//关闭工厂对象
public static void shutdown()
{
sessionFactory.close();
}
}
4-2:进行增删改查操作
package com.caokaiyuan.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;
import com.caokaiyuan.domain.User;
import com.caokaiyuan.util.SessionFactoryUtil;
public class TestClass
{
//保存数据
@Test
public void testSave()
{
//获得工厂对象
SessionFactory sessionFactory = SessionFactoryUtil.getSessionFactory();
//创建Session对象
Session session = sessionFactory.openSession();
//获得事务对象
Transaction tc = session.getTransaction();
//开始事务
tc.begin();
//创建User对象
User user = new User();
user.setUsername("tom1");
user.setPassword("1234");
//保存对象
session.save(user);
//提交事务
tc.commit();
session.close();
}
//删除数据
@Test
public void testDelete()
{
//获得SessionFactory工厂对象
SessionFactory sessionFactory = SessionFactoryUtil.getSessionFactory();
//创建Session对象
Session session = sessionFactory.openSession();
//获得事务对象
Transaction tc = session.getTransaction();
//开始事务
tc.begin();
//通过id查找对象
User user = (User)session.get(User.class, 2);
//删除对象
session.delete(user);
//提交事务
tc.commit();
//关闭会话
session.close();
}
//更新数据
@Test
public void testUpdate()
{
//获得SessionFactory工厂对象
SessionFactory sessionFactory = SessionFactoryUtil.getSessionFactory();
//创建Session对象
Session session = sessionFactory.openSession();
//获得是事务对象
Transaction tc = session.getTransaction();
//开始事务
tc.begin();
//通过id查找对象
User user = (User)session.get(User.class, 1);
user.setUsername("tomtom");
user.setPassword("456");
//保存更新数据
session.update(user);
//提交事务
tc.commit();
//关闭会话
session.close();
}
}
- Hibernate的增删改查
- Hibernate的增删改查
- Hibernate的增删查改
- Hibernate的增删改查
- Hibernate 的增删改查
- Hibernate的增删改查
- hibernate的增删改查
- Hibernate的增删改查
- Hibernate的增删改查
- hibernate的增删改查
- Hibernate的增删查改
- hibernate的增删改查
- hibernate增删查改
- hibernate增删改查
- Hibernate增删改查
- hibernate 增删改查
- hibernate 增删改查
- Hibernate 增删改查
- 4.替换空格||剑指offer
- nyoj 56
- Ubuntu 14.04下安装GitLab指南
- iOS开发之网络编程:Socket网络编程
- Linux命令行:Ping命令
- Hibernate的增删改查
- 杨辉三角形//第八届北京师范大学程序设计竞赛决赛
- JDK与JRE的一些问题
- 不用+,-,×,/做加法
- SWXMLHash XML文件解析
- 8.DBCP连接池技术操作MySQL
- PL/SQL练习题一(基础)
- Class热替换与卸载
- 页面JQuery日期转换