zoukankan      html  css  js  c++  java
  • JPA

    JPA入门:

    配置文件:
    <?xml version="1.0" encoding="UTF-8"?>
    <persistence version="2.0"
        xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
        <persistence-unit name="jpa-1" transaction-type="RESOURCE_LOCAL">
            <!--
            配置使用什么 ORM 产品来作为 JPA 的实现
            1. 实际上配置的是  javax.persistence.spi.PersistenceProvider 接口的实现类
            2. 若 JPA 项目中只有一个 JPA 的实现产品, 则也可以不配置该节点.
            -->
            <provider>org.hibernate.ejb.HibernatePersistence</provider>
        
            <!-- 添加持久化类 -->
            <class>com.atguigu.jpa.helloworld.Customer</class>
            <class>com.atguigu.jpa.helloworld.Order</class>
        
            <class>com.atguigu.jpa.helloworld.Department</class>
            <class>com.atguigu.jpa.helloworld.Manager</class>
        
            <class>com.atguigu.jpa.helloworld.Item</class>
            <class>com.atguigu.jpa.helloworld.Category</class>
            
            <!--
            配置二级缓存的策略
            ALL:所有的实体类都被缓存
            NONE:所有的实体类都不被缓存.
            ENABLE_SELECTIVE:标识 @Cacheable(true) 注解的实体类将被缓存
            DISABLE_SELECTIVE:缓存除标识 @Cacheable(false) 以外的所有实体类
            UNSPECIFIED:默认值,JPA 产品默认值将被使用
            -->
            <shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
        
            <properties>
                <!-- 连接数据库的基本信息 -->
                <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
                <property name="javax.persistence.jdbc.url" value="jdbc:mysql:///jpa"/>
                <property name="javax.persistence.jdbc.user" value="root"/>
                <property name="javax.persistence.jdbc.password" value="1230"/>
                
                <!-- 配置 JPA 实现产品的基本属性. 配置 hibernate 的基本属性 -->
                <property name="hibernate.format_sql" value="true"/>
                <property name="hibernate.show_sql" value="true"/>
                <property name="hibernate.hbm2ddl.auto" value="update"/>
                
                <!-- 二级缓存相关 -->
                <property name="hibernate.cache.use_second_level_cache" value="true"/>
                <property name="hibernate.cache.region.factory_class" value="org.hibernate.cache.ehcache.EhCacheRegionFactory"/>
                <property name="hibernate.cache.use_query_cache" value="true"/>
            </properties>
        </persistence-unit>
    </persistence>

    入门jar包

     

    bean:

    package com.atguigu.jpa.helloworld;

    import java.util.Date;
    import java.util.HashSet;
    import java.util.Set;

    import javax.persistence.Cacheable;
    import javax.persistence.CascadeType;
    import javax.persistence.Column;
    import javax.persistence.Entity;
    import javax.persistence.FetchType;
    import javax.persistence.GeneratedValue;
    import javax.persistence.GenerationType;
    import javax.persistence.Id;
    import javax.persistence.NamedQuery;
    import javax.persistence.OneToMany;
    import javax.persistence.Table;
    import javax.persistence.Temporal;
    import javax.persistence.TemporalType;
    import javax.persistence.Transient;
     
    @NamedQuery(name="testNamedQuery", query="FROM Customer c WHERE c.id = ?")
    @Cacheable(true)
    @Table(name="JPA_CUTOMERS")
    @Entity
    public class Customer {

        private Integer id;
        private String lastName;

        private String email;
        private int age;
        
        private Date createdTime;
        private Date birth;
        
        public Customer() {
            // TODO Auto-generated constructor stub
        }
        
        public Customer(String lastName, int age) {
            super();
            this.lastName = lastName;
            this.age = age;
        }



        private Set<Order> orders = new HashSet<>();

    //    @TableGenerator(name="ID_GENERATOR",
    //            table="jpa_id_generators",
    //            pkColumnName="PK_NAME",
    //            pkColumnValue="CUSTOMER_ID",
    //            valueColumnName="PK_VALUE",
    //            allocationSize=100)
    //    @GeneratedValue(strategy=GenerationType.TABLE,generator="ID_GENERATOR")
        @GeneratedValue(strategy=GenerationType.AUTO)
        @Id
        public Integer getId() {
            return id;
        }

        public void setId(Integer id) {
            this.id = id;
        }

        @Column(name="LAST_NAME",length=50,nullable=false)
        public String getLastName() {
            return lastName;
        }

        public void setLastName(String lastName) {
            this.lastName = lastName;
        }

        public String getEmail() {
            return email;
        }

        public void setEmail(String email) {
            this.email = email;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }
        
        @Temporal(TemporalType.TIMESTAMP)
        public Date getCreatedTime() {
            return createdTime;
        }

        public void setCreatedTime(Date createdTime) {
            this.createdTime = createdTime;
        }

        @Temporal(TemporalType.DATE)
        public Date getBirth() {
            return birth;
        }

        public void setBirth(Date birth) {
            this.birth = birth;
        }
        
        //映射单向 1-n 的关联关系
        //使用 @OneToMany 来映射 1-n 的关联关系
        //使用 @JoinColumn 来映射外键列的名称
        //可以使用 @OneToMany 的 fetch 属性来修改默认的加载策略
        //可以通过 @OneToMany 的 cascade 属性来修改默认的删除策略.
        //注意: 若在 1 的一端的 @OneToMany 中使用 mappedBy 属性, 则 @OneToMany 端就不能再使用 @JoinColumn 属性了.
    //    @JoinColumn(name="CUSTOMER_ID")
        @OneToMany(fetch=FetchType.LAZY,cascade={CascadeType.REMOVE},mappedBy="customer")
        public Set<Order> getOrders() {
            return orders;
        }

        public void setOrders(Set<Order> orders) {
            this.orders = orders;
        }

        //工具方法. 不需要映射为数据表的一列.
        @Transient
        public String getInfo(){
            return "lastName: " + lastName + ", email: " + email;
        }

        @Override
        public String toString() {
            return "Customer [id=" + id + ", lastName=" + lastName + ", email="
                    + email + ", age=" + age + ", createdTime=" + createdTime
                    + ", birth=" + birth + "]";
        }

    }

    测试方法:

  • 相关阅读:
    Spring 基于构造函数的依赖注入
    SpringMVC后台接受前台传值的方法
    Spring--jar包
    Ubuntu扩展磁盘空间
    在VScode中运行C/C++
    一个好用的C语言操作
    Python下载超快
    Python多线程
    C语言回调函数
    VScode中运行python
  • 原文地址:https://www.cnblogs.com/lshan/p/8625339.html
Copyright © 2011-2022 走看看