因为在学习Spring的时候学到有关数据库的章节的时候,提及到了hibernate的集成,可是我对hibernate技术差点儿是一点不了解。仅仅是知道它是一个orm对象映射框架,所以在初探的章节做一下hibernate的简单了解,以及应用。顺便提一句,我用的是maven加入的hibernate开发包

简单使用hibernate的一般步骤

*创建而且编辑hibernate配置文件

该配置文件主要是用于链接数据库所用,定义了数据库的驱动程序和映射文件的位置。例如以下是一个简单的配置

<?xml version="1.0" encoding="utf-8" ?

>
<!DOCTYPE hibernate-configuration
PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory > <property name="show_sql">true</property>
<property name="connection.driver_class">
org.gjt.mm.mysql.Driver
</property>
<property name="connection.url">
jdbc:mysql://localhost:3306/pgwt
</property>
<property name="connection.username">
root
</property>
<property name="connection.password">
1234
</property>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property> <mapping resource="com/springframework/hibernate/test.hbm.xml" /> </session-factory> </hibernate-configuration>

依据这个配置文件能够看出,全部的配置信息都是包括在<hibernate-configureation>标签之中,该配置文件和Spring的装配bean几乎相同,<session-factory>相应一个SessionFactory对象,期中配置的是对象中的属性,name代表属性的名称<property>标签的内容就是属性值了,逐一了解一下

show_sql属性是一个boolean值,代表的是在进行数据库操作的时候是否在控制台输出sql语句,在调试的时候很实用

connection.driver_class代表的是数据库的jdbc驱动程序,我这里使用的是mysql所以就是org.gjt.mm.mysql.Driver

connection.url代表的是訪问数据库的url

connection.username 代表的是登录数据库时候的用户名

connection.password 代表的是登录数据库时候的密码

dialect代表的是一种数据库的方言。能够为数据库中的属性设置一些默认值(我眼下是这么理解的,以后再深入研究一下)我知道了一个网页内容是数据库相应的方言的类。能够參考一下

url=iAtJN4kmEiQC1lt5ftCVhBoRUEsDf4YZ4jUaq9zuJDSjmnoVoPUWrEJ4hznScezJksTzlznOjYySoV4XBj7564m3EMAtwAguSjTwNmtLEoe">百度文库地址

<mapping resource=""/>标签是用来引用映射文件地址的,至于映射文件的内容。下文会做简单的介绍

*创建数据库表

简单的创建一个user的数据库表分别有userid,name,password字段

*创建和数据库表相应的javaBean类

例如以下是一个简单的javaBean

package com.springframework.hibernate;

public class User {

	private String userid;
private String name;
private String password; public String getUserid() {
return userid;
} public void setUserid(String userid) {
this.userid = userid;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} }

*创建映射文件

映射文件里包含了一些配置信息,代码之后会逐一介绍一下配置信息的含义,配置文件例如以下

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping>
<class name="com.springframework.hibernate.User" table="user">
<id name="userid" column="userid">
<generator class="assigned" />
</id>
<property name="name" column="name" />
<property name="password" column="password" />
</class>
</hibernate-mapping>

在上边的数据库表中包含三个字段。期中userid是主键。然后我来逐一说一下配置文件的含义

全部的配置信息都是写在<hebernate-mapping>标签中,期中能够包括多个<class>标签,目的是为了配置javaBean与数据库表之间的映射关系

<class>标签中name属性代表的是该class标签相应的javaBean,table属性代表该class标签相应的数据库表

<id> 标签是用于映射主键的。user表的主键是userid 。name属性是代表javaBean中属性的名称。column属性代表的是数据库表中的字段

<generator>标签定义了生成主键的方式,叫做生成器。我选择的方式是assigned。是由程序自由生成主键,相对还有其它集中方式,我找了一篇blog里面说的还挺具体blog地址

<property>也是像Spring注入javaBean一样,定义属性所相应的数据库表字段的引用column属性代表的是数据库表中的字段

*创建一个场景类(主函数)

代码例如以下

package com.springframework.hibernate;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; public class Client { public static void main(String[] args) {
try {
SessionFactory sf = new Configuration().configure()
.buildSessionFactory();
Session session = sf.openSession();
Transaction tx = session.beginTransaction(); for (int i = 0; i < 100; i++) {
User newuser = new User();
newuser.setUserid("userid" + i);
newuser.setName("name" + i);
newuser.setPassword("password" + i);
session.save(newuser);
} tx.commit();
session.close(); } catch (Exception e) {
e.printStackTrace();
}
}
}

这类似是一个样板是代码,应该是能够由Spring模板来替换的。

hibernate是通过SessionFactory来启动hibernate(通过配置文件与数据连接)。session对象其中包括一些数据库操作的方法

以上是一些使用hibernate的基本方法,了解了以上的知识就能够继续往下学习Spring了,以后再来完好有关hibernate的实战笔记。

hibernate实战笔记1---初探的更多相关文章

  1. Tars | 第0篇 腾讯犀牛鸟开源人才培养计划Tars实战笔记目录

    腾讯犀牛鸟开源人才培养计划Tars实战笔记目录 前言 在2021年夏,笔者参加了腾讯首届开源人才培养计划的Tars项目,负责Subset流量管理规则的Java语言JDK实现.其中写作几篇开源实战笔记, ...

  2. hibernate关联关系笔记

    Hibernate关联关系笔记 单向N:1 *  有连接表:在N方使用<join>/<many-to-one>.1方无需配置与之关联的持久化类. *  没有连接表:在N方使用& ...

  3. Hibernate学习笔记(二)

    2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...

  4. Hibernate学习笔记(一)

    2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...

  5. Hibernate 学习笔记一

    Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...

  6. mysql颠覆实战笔记(五)--商品系统设计(二):定时更新商品总点击量

    继续回到沈老师的MYSQL颠覆实战,首先回顾下上一节课的内容,请大家会看下上节课写的存储过程. 打开prod_clicklog表, 我们只要把日期(不含时分秒)的部分存在数据库中, 如果同一日期有相同 ...

  7. mysql颠覆实战笔记(四)--商品系统设计(一):商品主表设计

    版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...

  8. mysql颠覆实战笔记(一)--设计一个项目需求,灌入一万数据先

    版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...

  9. mysql颠覆实战笔记(七)--白话理解事务

    今天我们学习web开发级mysql颠覆实战课程第9课没MYSQL事务(一):白话理解事务.前面有两节课第7讲:商品系统设计(四):商品属性设计之自定义属性,第8讲:商品系统设计(五):一维属性的商品价 ...

随机推荐

  1. Maven+Docker,发布到Registry

    1.配置Pom.xml <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEnc ...

  2. photoshop制作古风画

    效果图: 素材结构: 前期准备: 素材准备,我的素材包括:印章.花束.二次元妹纸,背景图片. 软件准备,用的软件是 photoshop CS6. 把二次元妹纸拖入photoshop,把她抠出来,Ctr ...

  3. build.gradle(Mdule.app)依赖库相关

    dependencies { implementation fileTree(dir: 'libs', include: ['*.jar']) //noinspection GradleCompati ...

  4. 【Caffe】Ubuntu16.04上配置安装caffe(Only CPU)

    一.首先看看自己的系统,Ubuntu16.04,cpu,没有Nvidia,没有opencv 二.安装依赖包 安装protobuf,leveldb,snappy,OpenCV,hdf5, protobu ...

  5. Java中IO对象的输入输出流

    输入流: public void inputDemo () throws IOException { //文件名称 String fileName = "d:\\aaa.txt"; ...

  6. JNI数组操作

    在Java中数组分为两种: 1.基本类型数组 2.对象类型(Object[])的数组(数组中存放的是指向Java对象中的引用) 一个能通用于两种不同类型数组的函数: GetArrayLength(ja ...

  7. accmcolor

    accmcolor c; c.setcolorindex(1); playertablerecord.setcolor(c);

  8. ionic 创建某个文件下的page

    ionic g page 文件名 --pagesDir src/pages/about

  9. 【特 性】Attribute

    1 AttributeUsage [AttributeUsageAttribute(AttributeTargets.All, AllowMultiple = true, Inherited = tr ...

  10. 新版本的molar mass(uva-1586)明明debug过了,各种测试还是WA真是气死我了

    #include <bits/stdc++.h> using namespace std; double trans(string a) { stringstream ss; ss< ...