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

调试相关(show_sql   在控制台显示底层生成的sql语句 format_sql格式化sql语句)

<?xml version="1.0" encoding="UTF-8"?>

root

123456

jdbc:mysql://127.0.0.1:3306/library?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT&useSSL=true

com.mysql.cj.jdbc.Driver

org.hibernate.dialect.MySQLDialect

thread

true

true

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.对框架核心配置文件进行建模

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);

User user = session.get(User.class, 15);

user.setRealName(“小宝”);

// 6.提交事务(查询不需要事务)

Transaction.commit();

// 7.关闭session

session.close();

}

}

运行数据库效果如下:

3,删除

第一种方法:查询出然后删除

User user = session.get(User.class, 15);

session.delete(user);

第二中方法:new出来再删除

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值