hibernate实战笔记1---初探
因为在学习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---初探的更多相关文章
- Tars | 第0篇 腾讯犀牛鸟开源人才培养计划Tars实战笔记目录
腾讯犀牛鸟开源人才培养计划Tars实战笔记目录 前言 在2021年夏,笔者参加了腾讯首届开源人才培养计划的Tars项目,负责Subset流量管理规则的Java语言JDK实现.其中写作几篇开源实战笔记, ...
- hibernate关联关系笔记
Hibernate关联关系笔记 单向N:1 * 有连接表:在N方使用<join>/<many-to-one>.1方无需配置与之关联的持久化类. * 没有连接表:在N方使用& ...
- Hibernate学习笔记(二)
2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...
- Hibernate学习笔记(一)
2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...
- Hibernate 学习笔记一
Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...
- mysql颠覆实战笔记(五)--商品系统设计(二):定时更新商品总点击量
继续回到沈老师的MYSQL颠覆实战,首先回顾下上一节课的内容,请大家会看下上节课写的存储过程. 打开prod_clicklog表, 我们只要把日期(不含时分秒)的部分存在数据库中, 如果同一日期有相同 ...
- mysql颠覆实战笔记(四)--商品系统设计(一):商品主表设计
版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...
- mysql颠覆实战笔记(一)--设计一个项目需求,灌入一万数据先
版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...
- mysql颠覆实战笔记(七)--白话理解事务
今天我们学习web开发级mysql颠覆实战课程第9课没MYSQL事务(一):白话理解事务.前面有两节课第7讲:商品系统设计(四):商品属性设计之自定义属性,第8讲:商品系统设计(五):一维属性的商品价 ...
随机推荐
- 怎么用css hack处理各浏览器兼容IE6,IE7,IE8,IE9/ FF
第一:什么事浏览器兼容性 浏览器兼容性问题又被称为网页兼容性或网站兼容性问题,指网页在各种浏览器上的显示效果可能不一致而产生浏览器和网页间的兼容问题.在网站的设计和制作中,做好浏览器兼容,才能够让网站 ...
- 个人作业——Alpha项目测试
这个作业属于哪个课程 https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass1/ 这个作业要求在哪里 https://edu.cnbl ...
- vs for Mac中的启用Entity Framework Core .NET命令行工具
在vs for Mac的工具菜单中已没有了Package Manager Console. 我们可以通过以下方法使用Entity Framework Core .NET命令行工具: 1.添加Nuget ...
- 注解是建立在class文件基础上的东西,同C语言的宏有异曲同工的效果
注解是建立在class文件基础上的东西,同C语言的宏有异曲同工的效果 https://www.cnblogs.com/deman/p/5519901.html @是java注解,即annotation ...
- Gradle与Makefile构建工具的对比
随着Android Studio的普及,越来越多的Android开发者也要开始了解和学习Gradle这款强大的代码构建工具了.我们在学习和了解一项新事物的时候,最快速的方法往往是与已知的事物进行比较, ...
- CAD绘制一个角度标注(com接口VB语言)
主要用到函数说明: _DMxDrawX::DrawDimAngular 绘制一个角度标注.详细说明如下: 参数 说明 DOUBLE dAngleVertexX 角度标注的顶点的X值 DOUBLE dA ...
- CAD动态绘制多段线(com接口)
主要用到函数说明: _DMxDrawX::DrawLine 绘制一个直线.详细说明如下: 参数 说明 DOUBLE dX1 直线的开始点x坐标 DOUBLE dY1 直线的开始点y坐标 DOUBLE ...
- Git学习总结二(版本回退)
修改修改仓库中readme.txt文件,然后用git status命令看看结果: $ git status On branch master Changes not staged for commit ...
- oracle数据库视图,序列,索引的sql语句查看
1.视图:相当于表,可以用select * from tab;查看所有表和视图: 2.序列和索引可以利用select * from user_indexes 或者user_sequences;进行查看 ...
- POJ3278——Catch That Cow
Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 114140 Accepted: 35715 ...