org.hibernate.dialect.MySQLDialect
方言:决定框架底层生成哪个数据库的sql语句
3,在开发阶段再创建实体类和实体映射文件(*.hbm.xml)
建立 User.hbm.xml,配置映射文件
<?xml version="1.0" encoding="UTF-8"?><property insert=“false” update=“false” name=“createDatetime”
type=“java.sql.Timestamp” column=“create_datetime”>
name:类的全限定名
table:类对应的表
id标签:
name:类属性 type:类属性对应的java类型 column:数据库列段
property标签:
name:类属性 type:类属性对应的java类型 column:数据库列段
可以理解为:id标签是特殊的property标签
建立实体类
package com.ltf.one.entity;
import java.sql.Date;
import java.sql.Timestamp;
public class User {
private int id;
private String userName;
private String userPwd;
private String realName;
private String sex;
private Date birthday;
private Timestamp createDatetime;
private String remark;
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 getUserPwd() {
return userPwd;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
public String getRealName() {
return realName;
}
public void setRealName(String realName) {
this.realName = realName;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public Timestamp getcreateDatetime() {
return createDatetime;
}
public void setcreateDatetime(Timestamp createDatetime) {
this.createDatetime = createDatetime;
}
public String getRemark() {
return remark;
}
public void setRemark(String remark) {
this.remark = remark;
}
@Override
public String toString() {
return “User [id=” + id + “, userName=” + userName + “, userPwd=” + userPwd + “, realName=” + realName
-
“, sex=” + sex + “, birthday=” + birthday + “, createDatetime=” + createDatetime + “, remark=”
-
remark + “]”;
}
}
三,hibernate操作数据库实现
1,查询
编码步骤:
1.对框架核心配置文件进行建模
2.获取sessionFactory工厂
3.获取session会话
4.开启事务(查询不需要)
5.session操作对象
6.提交事务(查询不需要事务)
7.关闭session
package com.ltf.one.test;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class QueryDemo {
public static void main(String[] args) {
// 1.对框架核心配置文件进行建模
Configuration configure = new Configuration().configure();
// 2.获取sessionFactory工厂
SessionFactory SessionFactory = configure.buildSessionFactory();
// 3.获取session会话
Session session = SessionFactory.openSession();
// 5.session操作对象
List list = session.createQuery(“from User”).list();
for (Object object : list) {
System.out.println(object);
}
// 7.关闭session
session.close();
}
}
控制台输出对应的sql语句与查询的对象
运行过程中报如下错误,是因为实体类和实体映射文件的property标签:
name:类属性 type:类属性对应的java类型 column:数据库列段
没有完全对应
2, 增加
AddDemo
package com.ltf.one.test;
import java.sql.Date;
import java.sql.Timestamp;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.ltf.one.entity.User;
public class AddDemo {
public static void main(String[] args) {
// 1.对框架核心配置文件进行建模
Configuration configure = new Configuration().configure();
// 2.获取sessionFactory工厂
SessionFactory SessionFactory = configure.buildSessionFactory();
// 3.获取session会话
Session session = SessionFactory.openSession();
// 4.开启事务(查询不需要)
Transaction Transaction = session.beginTransaction();
// 5.session操作对象
User user = new User();
user.setBirthday(new Date(System.currentTimeMillis()));
user.setcreateDatetime(new Timestamp(System.currentTimeMillis()));
user.setId(11);
user.setRealName(“小宝巴士”);
user.setRemark(“肥皂剧”);
user.setSex(“2”);
user.setUserName(“孙佳怡”);
user.setUserPwd(“123456”);
session.save(user);
// 6.提交事务(查询不需要事务)
Transaction.commit();
// 7.关闭session
session.close();
}
}
输出结果如下图
数据库效果
在这里我们发现了一个问题,在增加的代码中我们设置了id为11,但是当数据进入数据库时,id变成了15,这是为什么呢?
原因是User.hbm.xml中的generator标签class属性为increment (自增)
不自增可改为assigned
hibernate的主键生成器:
generator元素:表示一个主键生成器
①程序员自己控制:assigned
②数据库控制:identity(标识列、自动增长)sequence
③hibernate控制:increment uuid/uuid.hex
④其他:native(int类型则自增,varchar类型则随机生成)
主键生成器要求
assigned:数据类型不限、保存前必须赋值
identity:数字,无需赋值
sequence:数字,无需赋值,默认使用hibernate_sequence这个序列
也可通过sequence/sequence_name参数赋值
increment:数字,无需赋值
uuid/uuid.hex:由容器生成一个32位的字符串
验证hibernate的特点
AddDemo,通过session获得对象并通过对象修改属性
将之前的小宝巴士改成小宝
package com.ltf.one.test;
import java.sql.Date;
import java.sql.Timestamp;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.ltf.one.entity.User;
public class AddDemo {
public static void main(String[] args) {
// 1.对框架核心配置文件进行建模
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
最后
资料过多,篇幅有限,需要文中全部资料可以点击这里免费获取前端面试资料PDF完整版!
自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。
系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-7kyFblEQ-1713488735787)]
[外链图片转存中…(img-xwHJZm6K-1713488735787)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
[外链图片转存中…(img-MRl608yi-1713488735788)]
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
[外链图片转存中…(img-Bxgy7nXc-1713488735788)]
最后
[外链图片转存中…(img-N19fwWtq-1713488735788)]
[外链图片转存中…(img-Iq8ewuZG-1713488735788)]
资料过多,篇幅有限,需要文中全部资料可以点击这里免费获取前端面试资料PDF完整版!
自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。