zoukankan      html  css  js  c++  java
  • Hibernate框架 主配置文件 Hibernate.cfg.xml 映射配置 说明

    1 主配置文件

    Hibernate.cfg.xml

             主配置文件中主要配置:数据库连接信息、其他参数、映射信息!

    常用配置查看源码:

             hibernate-distribution-3.6.0.Finalprojectetchibernate.properties

     

    <!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
    
    <hibernate-configuration>
        <!-- 通常,一个session-factory节点代表一个数据库 -->
        <session-factory>
        
            <!-- 1. 数据库连接配置 -->
            <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
            <property name="hibernate.connection.url">jdbc:mysql:///hib_demo?useUnicode=true&amp;characterEncoding=UTF8</property>
            <property name="hibernate.connection.username">用户名</property>
            <property name="hibernate.connection.password">密码</property>
            <!-- 
                    数据库方法配置,hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql
            -->
            <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
            
            <!-- 2. 其他相关配置 -->
            <!-- 2.1 显示hibernate在运行时候执行的sql语句 -->
            <property name="hibernate.show_sql">true</property>
            <!-- 2.2 格式化sql -->
            <property name="hibernate.format_sql">true</property>
            <!-- 2.3 自动建表  -->
            <property name="hibernate.hbm2ddl.auto">update</property>
            
            <!-- 3. 加载所有映射 -->
            <mapping resource="com/yif/a_hello/Employee.hbm.xml"/>
            
        </session-factory>
    </hibernate-configuration>

    2 数据库连接参数配置

    例如:

    ## MySQL

    #hibernate.dialect org.hibernate.dialect.MySQLDialect

    #hibernate.dialect org.hibernate.dialect.MySQLInnoDBDialect

    #hibernate.dialect org.hibernate.dialect.MySQLMyISAMDialect

    #hibernate.connection.driver_class com.mysql.jdbc.Driver

    #hibernate.connection.url jdbc:mysql:///test

    #hibernate.connection.username gavin

    #hibernate.connection.password

    <!-- 1. 数据库连接配置 -->
            <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
            <property name="hibernate.connection.url">jdbc:mysql:///hib_demo?useUnicode=true&amp;characterEncoding=UTF8</property>
            <property name="hibernate.connection.username">用户名</property>
            <property name="hibernate.connection.password">密码</property>
            <!-- 
                    数据库方法配置,hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql
            -->
            <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
            

    2.1 自动建表

    Hibernate.properties

    #hibernate.hbm2ddl.auto create-drop 每次在创建sessionFactory时候执行创建表;

                                                                               当调用sesisonFactory的close方法的时候,删除表!

    #hibernate.hbm2ddl.auto create   每次都重新建表; 如果表已经存在就先删除再创建<property name="hibernate.hbm2ddl.auto">create</property>

    #hibernate.hbm2ddl.auto update  如果表不存在就创建; 表存在就不创建; <property name="hibernate.hbm2ddl.auto">update</property>

    #hibernate.hbm2ddl.auto validate  (生成环境时候) 执行验证: 当映射文件的内容与数据库表结构不一样的时候就报错!

    <!-- 2. 其他相关配置 -->
            <!-- 2.1 显示hibernate在运行时候执行的sql语句 -->
            <property name="hibernate.show_sql">true</property>
            <!-- 2.2 格式化sql -->
            <property name="hibernate.format_sql">true</property>
            <!-- 2.3 自动建表  -->
            <property name="hibernate.hbm2ddl.auto">update</property>
            
            <!-- 3. 加载所有映射 -->
            <mapping resource="com/yif/a_hello/Employee.hbm.xml"/>

    当使用

    // 创建sf对象
            sf = new Configuration()
                .configure()
                .addClass(User.class)  //(测试) 会自动加载映射文件:Employee.hbm.xml
                .buildSessionFactory();

    用以上语句可以 不用在主配置文件中 写  <!-- 3. 加载所有映射 --> <mapping resource="com/yif/a_hello/Employee.hbm.xml"/>

    2.2 手动建表

    public class App_ddl {
    
        // 自动建表
        @Test
        public void testCreate() throws Exception {
            // 创建配置管理类对象
            Configuration config = new Configuration();
            // 加载主配置文件
            config.configure();
            
            // 创建工具类对象
            SchemaExport export = new SchemaExport(config);
            // 建表
            // 第一个参数: 是否在控制台打印建表语句
            // 第二个参数: 是否执行脚本
            export.create(true, true);
        }
    }

    3 映射配置

    3.1 普通字段类型

    3.2 主键映射

             单列主键映射

             多列作为主键映射

    主键生成策略,查看api:   5.1.2.2.1. Various additional generators

    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    
    <!-- 映射文件: 映射一个实体类对象;  描述一个对象最终实现可以直接保存对象数据到数据库中。  -->
    <!-- 
        package: 要映射的对象所在的包(可选,如果不指定,此文件所有的类都要指定全路径)
        auto-import 默认为true, 在写hql的时候自动导入包名
                    如果指定为false, 再写hql的时候必须要写上类的全名;
                      如:session.createQuery("from cn.itcast.c_hbm_config.Employee").list();
     -->
    <hibernate-mapping package="cn.itcast.c_hbm_config" auto-import="true">
        
        <!-- 
            class 映射某一个对象的(一般情况,一个对象写一个映射文件,即一个class节点)
                name 指定要映射的对象的类型
                table 指定对象对应的表;
                      如果没有指定表名,默认与对象名称一样 
         -->
        <class name="Employee" table="employee">
            
            <!-- 主键 ,映射-->
            <id name="empId" column="id">
                <!-- 
                    主键的生成策略
                        identity  自增长(mysql,db2)
                        sequence  自增长(序列), oracle中自增长是以序列方法实现
                        native  自增长【会根据底层数据库自增长的方式选择identity或sequence】
                                如果是mysql数据库, 采用的自增长方式是identity
                                如果是oracle数据库, 使用sequence序列的方式实现自增长
                        
                        increment  自增长(会有并发访问的问题,一般在服务器集群环境使用会存在问题。)
                        
                        assigned  指定主键生成策略为手动指定主键的值
                        uuid      指定uuid随机生成的唯一的值
                        foreign   (外键的方式, one-to-one讲)
                 -->
                <generator class="uuid"/>
            </id>
            
            <!-- 
                普通字段映射
                property
                    name  指定对象的属性名称
                    column 指定对象属性对应的表的字段名称,如果不写默认与对象属性一致。
                    length 指定字符的长度, 默认为255
                    type   指定映射表的字段的类型,如果不指定会匹配属性的类型
                        java类型:     必须写全名
                        hibernate类型:  直接写类型,都是小写
            -->
            <property name="empName" column="empName" type="java.lang.String" length="20"></property>
            <property name="workDate" type="java.util.Date"></property>
            <!-- 如果列名称为数据库关键字,需要用反引号或改列名。 -->
            <property name="desc" column="`desc`" type="java.lang.String"></property>
            
        </class>
        
    
    </hibernate-mapping>

    3.3 复合主键映射

    User 类   主键需要单独为类

    public class User {
    
        // 名字跟地址,不会重复
        private CompositeKeys keys;
        private int age;
        
        public CompositeKeys getKeys() {
            return keys;
        }
        public void setKeys(CompositeKeys keys) {
            this.keys = keys;
        }
        public int getAge() {
            return age;
        }
        public void setAge(int age) {
            this.age = age;
        }
        
        
        
    }

    主键类:必须实现 序列化

     读取?
        主键查询,
        //构建主键查询
        //构建主键再查询
            CompositeKeys keys = new CompositeKeys();
            keys.setAddress("广州棠东");
            keys.setUserName("Jack");
            
            // 主键查询
            User user = (User) session.get(User.class, keys);  后面的id 是 Serializable
    import java.io.Serializable;
    
    // 复合主键类
    public class CompositeKeys implements Serializable{
        private String userName;
        private String address;
        public String getUserName() {
            return userName;
        }
        public void setUserName(String userName) {
            this.userName = userName;
        }
        public String getAddress() {
            return address;
        }
        public void setAddress(String address) {
            this.address = address;
        }
        
    }
    <?xml version="1.0"?>
    <!DOCTYPE hibernate-mapping PUBLIC 
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
    
    <hibernate-mapping package="cn.itcast.d_compositeKey" auto-import="true">
        
        <class name="User">
            
            <!-- 复合主键映射 -->
            <composite-id name="keys">
                <key-property name="userName" type="string"></key-property>
                <key-property name="address" type="string"></key-property>
            </composite-id>
            
            <property name="age" type="int"></property>        
            
        </class>
        
    
    </hibernate-mapping>
  • 相关阅读:
    信息领域热词分类分析03
    虚拟机Linux联网问题
    每日学习
    第七章 Centos下搭建Maven私有仓库
    第六章 Maven-profile及插件
    第五章 Maven-构建生命周期、阶段、目标
    第四章 Maven-依赖管理
    第三章 Maven-pom.xml文件
    第二章 Maven-Repository存储库
    第一章 Maven入门
  • 原文地址:https://www.cnblogs.com/loveincode/p/5466974.html
Copyright © 2011-2022 走看看