2018-03-15

Hibernate

使用JDBC做数据库相关功能开发会做很多重复性的工作,比如创建连接,关闭连接,把字段逐一映射到属性中。 Hibernate把这一切都封装起来了,使得数据库访问变得轻松而简单,代码也更加容易维护。

  1. 创建一个实体类Product,这个实体类可以映射数据库中的表product_,
package com.ghw.pojo;
public class Product {
    int id;
    String name;
    float price;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public float getPrice() {
        return price;
    }
    public void setPrice(float price) {
        this.price = price;
    } 
}
  1. 配置Product.hbm.xml,用于映射Product类对应数据库中的表。


 

    
        
            
            
        
        
        
    
     

在包com.ghw.pojo下 新建一个配置文件Product.hbm.xml, 用于映射Product类对应数据库中的product_
: 文件名Product.hbm.xmlP一定要大写,要和类保持一致


表示类Product对应表product_





表示属性id,映射表里的字段id
意味着id的自增长方式采用数据库的本地方式
如果是连接oracle数据库,可以指定sequnce作为id自增长方式


这里配置的时候,只写了属性name,没有通过column="name" 显式的指定字段,那么字段的名字也是name.

配置 hibernate.cfg.xml

在src目录下创建 hibernate.cfg.xml
配置访问数据库要用到的驱动,url,账号密码等等
其他配置及含义:

org.hibernate.dialect.MySQLDialect

这表示使用MYSQL方言。 什么方言呢? 因为在代码层面,开发人员不用关心底层到底用Oracle还是Mysql,写的代码都是一样的。 可是Oracle和Mysql所用的sql语句的语法是有所区别的,那么这件事就交给Hibernate来做了。这个时候就需要告诉Hibernate底层用的是什么数据库,它才知道应该用什么样的“方言” 去对话。

thread

这是Hibernate事务管理方式,即每个线程一个事务

true

这表示是否在控制台显示执行的sql语句

update

这表示是否会自动更新数据库的表结构,有这句话,其实是不需要创建表的,因为Hibernate会自动去创建表结构


这表示Hibernate会去识别Product这个实体类



 

 
    
        
        com.mysql.jdbc.Driver
        jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8
        root
        admin
        
        org.hibernate.dialect.MySQLDialect
        thread
        true
        update
        
    
 

你可能感兴趣的:(2018-03-15)