Hibernate.cfg.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <!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> <!-- 连接数据库的基本参数 --> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql:///hibernate_day03</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">123456</property> <!-- 配置Hibernate的方言 --> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 可选配置================ --> <!-- 打印SQL --> <property name="hibernate.show_sql">true</property> <!-- 格式化SQL --> <property name="hibernate.format_sql">true</property> <!-- 自动创建表 --> <property name="hibernate.hbm2ddl.auto">update</property> <!-- 配置C3P0连接池 --> <property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <!--在连接池中可用的数据库连接的最少数目 --> <property name="c3p0.min_size">5</property> <!--在连接池中所有数据库连接的最大数目 --> <property name="c3p0.max_size">20</property> <!--设定数据库连接的过期时间,以秒为单位, 如果连接池中的某个数据库连接处于空闲状态的时间超过了timeout时间,就会从连接池中清除 --> <property name="c3p0.timeout">120</property> <!--每3000秒检查所有连接池中的空闲连接 以秒为单位--> <property name="c3p0.idle_test_period">3000</property> <!-- 设置事务隔离级别 --> <property name="hibernate.connection.isolation">4</property> <!-- 配置当前线程绑定的Session --> <property name="hibernate.current_session_context_class">thread</property> <!-- 引入映射 --> <mapping resource="com/xxx/hibernate/domain/Customer.hbm.xml"/> <mapping resource="com/xxx/hibernate/domain/LinkMan.hbm.xml"/> </session-factory> </hibernate-configuration>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="com.itheima.hibernate.domain.Customer" table="cst_customer"> <!-- 建立OID与主键映射 --> <id name="cust_id" column="cust_id"> <generator class="native"/> </id> <!-- 建立普通属性与数据库表字段映射 --> <property name="cust_name" column="cust_name" /> <property name="cust_source" column="cust_source"/> <property name="cust_industry" column="cust_industry"/> <property name="cust_level" column="cust_level"/> <property name="cust_phone" column="cust_phone"/> <property name="cust_mobile" column="cust_mobile"/> <!-- 配置一对多的映射:放置的多的一方的集合 --> <!-- set标签 : * name :多的一方的对象集合的属性名称。 * cascade:级联 * inverse:一的一方放弃外键维护权。 --> <set name="linkMans" cascade="save-update,delete" inverse="true"> <!-- key标签 * column:多的一方的外键的名称。 --> <key column="lkm_cust_id"/> <!-- one-to-many标签 * class :多的一方的类的全路径 --> <one-to-many class="com.itheima.hibernate.domain.LinkMan"/> </set> </class> </hibernate-mapping>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="com.itheima.hibernate.domain.LinkMan" table="cst_linkman"> <!-- 建立OID与主键映射 --> <id name="lkm_id" column="lkm_id"> <generator class="native"/> </id> <!-- 建立普通属性与表字段的映射 --> <property name="lkm_name"/> <property name="lkm_gender"/> <property name="lkm_phone"/> <property name="lkm_mobile"/> <property name="lkm_email"/> <property name="lkm_qq"/> <property name="lkm_position"/> <property name="lkm_memo"/> <!-- 配置多对一的关系:放置的是一的一方的对象 --> <!-- 多的一方 many-to-one标签 *name:一的一方的对象的属性名称。 *class:一的一方的类的全路径 *column:在多的一方的表的外键的名称 --> <many-to-one name="customer" cascade="save-update,delete" class="com.itheima.hibernate.domain.Customer" column="lkm_cust_id"/> </class> </hibernate-mapping >
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE hibernate-mapping PUBLIC"-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping><class name="com.itheima.hibernate.domain.LinkMan" table="cst_linkman"><!-- 建立OID与主键映射 --><id name="lkm_id" column="lkm_id"><generator class="native"/></id><!-- 建立普通属性与表字段的映射 --><property name="lkm_name"/><property name="lkm_gender"/><property name="lkm_phone"/><property name="lkm_mobile"/><property name="lkm_email"/><property name="lkm_qq"/><property name="lkm_position"/><property name="lkm_memo"/><!-- 配置多对一的关系:放置的是一的一方的对象 --><!--多的一方many-to-one标签*name:一的一方的对象的属性名称。*class:一的一方的类的全路径*column:在多的一方的表的外键的名称--><many-to-one name="customer" cascade="save-update,delete" class="com.itheima.hibernate.domain.Customer" column="lkm_cust_id"/></class></hibernate-mapping >