xml文件【封装】写SQL语句
<class class='com.briup.user',table='s_emp'>
<property name='id' column='id' type=''></propert>
<property name='name' column='name' type=''></propert>
<property name='age' column='age' type=''></propert>
</class>
解析后的语句:insert into s_emp values();
拼接;
判断插入的值与数据库中的类型是否一致。
hibernate本质的作用:从繁琐的SQL语句中解脱出来
对象持久化【应用层和DAO层的连接(查询,更新,持久化)】
ORM(object relational mapping)【对象关系映射】
orm代表的是:对象和关系型数据库的关系
域和关系型数据库的映射;
类和表的映射;
一个类对应数据库中的一个表;
类里面的对象对应着表里的一行数据;
对象里的属性对应表里的列。
user.java
user.hbm.xml这个文件是对象和关系型数据库完整的映射
hibernate.cfg.xml这个文件配置的是连接数据库需要的一些属性和相应数据源、其他配置

configuration根hibernate,作用就是读取我们的配置文件
hibernate.cfg.xml
transaction事务,在hibernate是单独被提取出来的
query操作数据库的,基于session对象
jar包导入
hibernate.jar
ojdbc14.jar
hibernate依赖的jar包:核心jarhelib

POJO类----Bean【实体对象(一般情况只有属性,方法有属性的get/set、还有就是重写Object的一些方法)】
user         create table s_user(
id int        id number
name String    name varchar2(20)
age int        age number
gender String    gender varchar2(20)
bird Date       bird Date);
create table s_user(
id number primary key,
name varchar2(20),
age number,
gender varchar2(20),
bird Date
);

用get或者load方式加载数据
get没有值返回的是一个null
get首先根据第二个参数去一级缓存session中找,找不到二级缓存
最后到数据库中去找,数据库找不到返回null值
load首先到一级缓存找,没有到二级缓存找,二级缓存也没有找到
,这是看程序中是否调用获取对象的属性(是否只是单纯的接受了参数),
如果不是,采取延迟加载,返回一个id为你设置的值代理对象
不会执行sql语句,如果是获取了属性,会道数据库找,
找到返回,找不到报异常ObjectNotFoundException
HQL 面向对象的hql语句
sql select * from s_emp;
hql from User u where u.name="";
User代表类名 u.name代表的是User里面的属性
hql 查询时基于query这个接口
hibernate 里面对时间java.util.Date可以直接使用

为什么使用ORM?
高效、呈现形式好
ORM中间键
Hibernate
Apache OJB
Ibatis

SQL数据库
数据检索:select
数据操作语言【DML】:insert update delete
数据定义语言【DDL】:create alter drop rename truncate
事物【DCL】:commit rollback savepoint

第一步:建立POJO类或实体Bean

import java.util.Date;

public class User {
private long id;
private String name;
private int age;
private String gender;
private Date bird;
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public Date getBird() {
return bird;
}
public void setBird(Date bird) {
this.bird = bird;
}
}

第二步:建表

drop table s_user;
create table s_user(
id number primary key,
name varchar2(20),
age number,
gender varchar2(20),
bird date
);

第三步:配置ORM映射,XXX.hbm.xml XXX代表的是类名

<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.briup.Bean">
<class name="User" table="s_user">
<!-- 主键的生成策略 -->
<id name="id" column="id">
<generator class="increment"></generator>
</id>
<!-- 属性 -->
<property name="name" column="name"></property>
<property name="age" column="age"></property>
<property name="gender" column="gender"></property>
<property name="bird" column="bird"></property>
</class>
</hibernate-mapping>

第四步:配置hibernate.cfg.xml,文件位置在src下

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 数据库的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</property>
<!-- 数据库的四要素 -->
<property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="hibernate.connection.username">victor</property>
<property name="hibernate.connection.password">victor</property>
<property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:XE</property>
<property name="hibernate.show_sql">true</property>
<property name="format SQL in log and console hibernate.format_sql">true</property>
<mapping resource="com/***/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>

第五步:写测试程序

import java.util.Date;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

public class Test {
public static void main(String[] args) {
//调用user的时候就会根据User.class去缓存中
//找到相应的内容
//读取配置文件
Configuration conf=new Configuration();
conf.configure();
//建立session的工厂
//SessionFactory重量级【代表会把所有的服务给予】线程安全的是hibernate的一级缓存
//一个数据库里不能总是销毁和重建sessionfactory对象
//维护一个二级缓存
//加载XML文件的时候根据配置文件建立相应的SQL语句
//insert into s_user values(id,name,age,gender,bird);
//建立好放在缓存中
SessionFactory sf=conf.buildSessionFactory();
//根据给出的driver url username password 取货数据库的连接
//建立连接池【建立若干个对象】
//session是hibernate的一级缓存
//线程不安全,session不能被公用
Session session=sf.openSession();
//把事务单独提取出来
Transaction tran=session.beginTransaction();
//持久化保存数据
/*//向数据库中添加数据库或修改数据
User user=new User();
//user.setId(1);
//[这个操作是判断数据库中是否有id=0的用户,有则需改,没有则添加]
user.setName("lihao");
user.setAge(15);
user.setGender("男");
user.setBird(new Date());
//调用user的时候就会根据User.class去缓存中找到相应的内容
session.save(user);*/
//主键序列添加用户信息
//session.saveOrUpdate(user);
//要插入的id无用户信息则进行添加操作,如果有用户信息则修改该id的信息
//用get或者load方式只能基于主键
/*//get方式加载数据
User user1=(User) session.get(User.class, 1L);
//System.out.println(user1);
//输出的是地址
user1.setGender("男");
session.save(user1);
//load方式加载数据
User user2=(User) session.load(User.class, 2L);
//System.out.println(user2);
user2.setGender("男");
session.save(user2);*/
/*//查询数据库中所有的数据
//用sql语句翻译 select * from s_user;
String hql="from User";
Query query=session.createQuery(hql);
List<User> list=query.list();
System.out.println(list);*/
//查询一条结果
//String hql="from User where id="+2;
String hql="from User where name='lisi'";
Query query=session.createQuery(hql);
List<User> list=query.list();
//操作删除
/*String hql="delete from User";
Query query=session.createQuery(hql);
query.executeUpdate();*/
tran.commit();
session.close();
}
}

Hibernate学习笔记1的更多相关文章

  1. Hibernate学习笔记(二)

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

  2. Hibernate学习笔记(一)

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

  3. Hibernate 学习笔记一

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

  4. Hibernate学习笔记-Hibernate HQL查询

    Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库 ...

  5. Hibernate学习笔记

    一.Hibernate基础 1.Hibernate简介 Hibernate是一种对象关系映射(ORM)框架,是实现持久化存储的一种解决方案.Java包括Java类到数据库表的映射和数据查询及获取的方法 ...

  6. Hibernate学习笔记(四)

    我是从b站视频上学习的hibernate框架,其中有很多和当前版本不符合之处,我在笔记中进行了修改以下是b站视频地址:https://www.bilibili.com/video/av14626440 ...

  7. Hibernate学习笔记(三)

    我是从b站视频上学习的hibernate框架,其中有很多和当前版本不符合之处,我在笔记中进行了修改以下是b站视频地址:https://www.bilibili.com/video/av14626440 ...

  8. HIbernate学习笔记(一) 了解hibernate并搭建环境建立第一个hello world程序

    Hibernate是一个开放源代码的ORM(对象关系映射)框架,它对JDBC进行了轻量级的封装,Java程序员可以使用面向对象的编程思维来操纵数据库,它通过对象属性和数据库表字段之间的映射关系,将对象 ...

  9. Hibernate学习笔记-Hibernate关系映射

    1. 初识Hibernate——关系映射 http://blog.csdn.net/laner0515/article/details/12905711 2. Hibernate 笔记8 关系映射1( ...

  10. Hibernate学习笔记(1)Hibernate构造

    一 准备工作 首先,我们将创建一个简单的基于控制台(console-based)Hibernate应用. 我们所做的第一件事就是创建我们的开发文件夹.并把所有需要用到的Java件放进去.解压缩从Hib ...

随机推荐

  1. 百度编辑器UEditor ASP.NET示例Demo 分类: ASP.NET 2015-01-12 11:18 346人阅读 评论(0) 收藏

    在百度编辑器示例代码基础上进行了修改,封装成类库,只需简单配置即可使用. 完整demo下载 版权声明:本文为博主原创文章,未经博主允许不得转载.

  2. Python 遍历文件,字符串操作

    写一个简单的脚本,循环遍历单层文件夹,检查源代码中是否有一些特殊的类. import os import codecs dirroot = "......" line_num = ...

  3. 单链表带头结点&不带头结点

    转自:http://blog.csdn.net/xlf13872135090/article/details/8857632 Node *head;  //声明头结点   带头结点初始化 void I ...

  4. VS2013安装oepncv2.4.10 以及opencv 3.0.0

    Author:Maddock Date:2014.12.27 …………………………………………………………………………………………………… PS: VS2013 + OPENCV 3.0.0 的安装, ...

  5. 函数调用关于从Ring3转到Ring0 ESP堆栈变化

    在ring0堆栈获取ring3堆栈方式 第一种方式 [esp+4] == [esp+参数个数*4+4] 如果这里不相等就需要用第二种方式 [[esp+参数个数*4+8]] 这里面的值就是Ring3的堆 ...

  6. 【jQuery 区别】attr()和prop()的区别

    1>>> 今天实现一个 点击更新按钮 ,可以勾选上本行的的checkbox的功能: 使用代码: /** * updateproduct.htmls 更新 产品信息 */ $(docu ...

  7. winmail服务器启动失败 无法启动

    1.解决句柄问题:打开命令行:开始 -> 运行-> 输入 cmd -> 确定.切换命令目录至winmail的服务目录,我的是:E:\htdocs\Winmail\server\> ...

  8. Ubuntu中如何打开终端terminal

    法一 先按住Alt,然后再按F2,出来一个运行框,在里面输入gnome-terminal即可 [编辑]法二 如果想从右键菜单中打开终端,需要安装一个软件: sudoapt-get install na ...

  9. Uva 129 Krypton Factor

    0.这道题的输出 处理起来挺麻烦的 以后类似的可以借鉴一下 ;i<cur;i++) { && i%==) printf("\n%c",a[i]); & ...

  10. TStringList 常用操作

    //TStringList 常用方法与属性: var   List: TStringList;   i: Integer; begin   List := TStringList.Create;   ...