hibernate入门与主键生成策略以及增删改查的实现

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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合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完整版!

自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。

  • 28
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值