1、复习
1.1Hibernate:
ORM:(对象关系映射)
表和类关联
行和对象关联
字段和属性关联
工作流程:
1、加载配置(核心配置文件和映射文件)
2、得到sessionFactory
3、得到session
4、开启事务
5、操作数据
6、提交事务
7、关闭链接
2、(IDEA)hibernate生成实体类:自动模式
使用插件帮助我们生成映射文件和实体类
第一步:配置DB视图:
数据库中已经有的表:
配置IDE:(Database -> + ->Data Source -> MySQL):
链接成功:
第二步:创建项目 导入依赖:
导入依赖 前一个博客…
第三步:给插件添加Hibernate插件支持
第四步:生成对应表的实体类和映射文件:
生成内容:主要看映射文件
<?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.lemon.pojo.UserinfoEntity" table="userinfo" schema="hibernate">
<id name="uid">
<column name="uid" sql-type="int(11)"/>
</id>
<property name="userName">
<column name="user_name" sql-type="varchar(100)" length="100" not-null="true"/>
</property>
<property name="userPass">
<column name="user_pass" sql-type="varchar(100)" length="100" not-null="true"/>
</property>
</class>
</hibernate-mapping>
不足之处:
1、生成的内容:
缺少主键策略
2、添加主键策略:
3、注意:
带下划线的字段处理:
再次调出生成视图:(再次生成其他表的实体类和映射文件)
第五步:创建hibernate的核心配置文件:
<!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>
<!--*************1.数据源********************-->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">
jdbc:mysql://127.0.0.1:3307/hibernate?characterEncoding=utf-8
</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">password</property>
<!--扩展属性 必须指向数据库的方言 mysql版本低于5.5用MySQL5Dialect-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL55Dialect</property>
<!--自动创建表 一般不需要 常规项目先做数据库表-->
<!--update自动更新-->
<!-- <property name="hbm2ddl.auto">update</property>-->
<!--显示SQL-->
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property><!--格式化 好看一点-->
<!--**********2.注册实体*************************-->
<mapping resource="com/lemon/pojo/UserinfoEntity.hbm.xml"></mapping>
</session-factory>
</hibernate-configuration>
第六步:开发dao测试
1、工具类:
package com.lemon.utils;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
/**
* 工具类:
*/
public class YtUserUtils {
private static SessionFactory sessionFactory;
static {
Configuration configuration = new Configuration();
configuration.configure("hibernate.cfg.xml");
sessionFactory = configuration.buildSessionFactory();
}
public static Session openSession(){
return sessionFactory.openSession();
}
}
2、dao测试:
package com.lemon.dao;
import com.lemon.pojo.UserinfoEntity;
import com.lemon.utils.YtUserUtils;
import org.hibernate.Session;
import org.hibernate.Transaction;
/**
* 测试:
* @author lemonsun
*/
public class UserDao {
//添加
public void addUser(UserinfoEntity userinfoEntity){
//得到session
Session session = YtUserUtils.openSession();
//开启事务
Transaction transaction = session.beginTransaction();
//操作数据
session.save(userinfoEntity);
//提交事务
transaction.commit();
//关闭链接
session.close();
}
//查找
public void findById(Integer uid){
//得到session
Session session = YtUserUtils.openSession();
//操作数据
//查询
UserinfoEntity userinfoEntity = session.get(UserinfoEntity.class, uid);
//输出:
System.out.println(userinfoEntity.getUserName());
System.out.println(userinfoEntity.getUserPass());
//关闭链接
session.close();
}
public static void main(String[] args) {
UserDao userDao = new UserDao();
//插入数据
/* UserinfoEntity userinfoEntity = new UserinfoEntity();
userinfoEntity.setUserName("测试自动生成>>>");
userinfoEntity.setUserPass("测试自动生成...");
userDao.addUser(userinfoEntity);*/
//查询数据
userDao.findById(1);
}
}