1需求

​ 向客户中插入一条数据

​ 如果使用Jpa框架可以不用先建表 可以使用框架生成表

​ 2 实现步骤

​ a 创建工程 使用maven管理工程

 <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <project.hibernate.version>5.0.7.Final</project.hibernate.version>
      <maven.compiler.source>1.8</maven.compiler.source>
      <maven.compiler.target>1.8</maven.compiler.target>
  </properties>
  <dependencies>
      <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>4.12</version>
      </dependency>
      <!--hibernate 对jpa的支持-->
      <dependency>
          <groupId>org.hibernate</groupId>
          <artifactId>hibernate-entitymanager</artifactId>
          <version>${project.hibernate.version}</version>
      </dependency>
      <dependency>
          <groupId>org.hibernate</groupId>
          <artifactId>hibernate-c3p0</artifactId>
          <version>${project.hibernate.version}</version>
      </dependency>
      <dependency>
          <groupId>log4j</groupId>
          <artifactId>log4j</artifactId>
          <version>1.2.17</version>
      </dependency>
      <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>5.1.6</version>
      </dependency>
  </dependencies>

​ b 创键一个配置文件

​ 配置文件的路径必须是:META-INF/persistence.xml

​ 配置连接数据库的相关配置

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
  <!--配置持久化单元 在配置文件中至少有一个
      name 持久化单元的名称
      transaction-type   事物类型
      RESOURCE_LOCAL   单数据库的事物
      JTA 分布式事物 跨数据的事物   多个数据库的事物


  -->
  <persistence-unit name="myjpa" transaction-type="RESOURCE_LOCAL">
      <properties>
          <property name="javax.persistence.jdbc.user" value="root"/>
          <property name="javax.persistence.jdbc.password" value="root"/>
          <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
          <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/sprign_data-9501"/>
      <!--配置hibernate的属性-->
          <property name="hibernate.show_sql" value="true"></property>
          <!--sql语句是否格式化-->
          <property name="hibernate.format_sql" value="true"/>
          <!--是否自动创建数据库表
            value 可选值   create update   none
            create 程序自动创建数据库表 如果表存在 先删除后创建
            update 程序自动创建数据库表 如果表存在 不创建
            none   不会创建
          -->
          <property name="hibernate.hbm2ddl.auto" value="create"/>
      </properties>
  </persistence-unit>
</persistence>

​ c: 创键一个Entry类 对应数据库中每个表创键一个实体类

package cn.lijun.jpa.entity;

import javax.persistence.*;

/**
* @author lijun
* @date 2019/8/14 10:38
*/
// 该类是jpa的实体类
@Entity
// 配置实体类和数据库表中映射关系   name   对应的表名

@Table(name="cust_customer")
public class Customer {
  // 配置主键的生成策略     GenerationType.IDENTITY   自增长
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  @Id
  //配置属性和字段名之间关系
  @Column(name="cust_id")
  private long custId;
  @Column(name="cust_name")
  private String custName;
  @Column(name="cust_source")
  private String custSource;
  @Column(name="cust_industry")
  private String custIndustry;
  @Column(name="cust_level")
  private String custLevel;
  @Column(name="cust_address")
  private String custAddress;
  @Column(name="cust_phone")
  private String custPhone;

  public long getCustId() {
      return custId;
  }

  public void setCustId(long custId) {
      this.custId = custId;
  }

  public String getCustNmae() {
      return custName;
  }

  public void setCustName(String custName) {
      this.custName = custName;
  }

  public String getCustSource() {
      return custSource;
  }

  public void setCustSource(String custSource) {
      this.custSource = custSource;
  }

  public String getCustIndustry() {
      return custIndustry;
  }

  public void setCustIndustry(String custIndustry) {
      this.custIndustry = custIndustry;
  }

  public String getCustLevel() {
      return custLevel;
  }

  public void setCustLevel(String custLevel) {
      this.custLevel = custLevel;
  }

  public String getCustAddress() {
      return custAddress;
  }

  public void setCustAddress(String custAddress) {
      this.custAddress = custAddress;
  }

  public String getCustPhone() {
      return custPhone;
  }

  public void setCustPhone(String custPhone) {
      this.custPhone = custPhone;
  }

  @Override
  public String toString() {
      return "Customer{" +
              "custId=" + custId +
              ", custName='" + custName + '\'' +
              ", custSource='" + custSource + '\'' +
              ", custIndustry='" + custIndustry + '\'' +
              ", custLevel='" + custLevel + '\'' +
              ", custAddress='" + custAddress + '\'' +
              ", custPhone='" + custPhone + '\'' +
              '}';
  }
}

​ d: 编写测试程序 实现数据的添加

​ 1 创键一个EntityManagerFactory 对象 使用完关闭

​ 2 使用工厂对象EntityManagerFactory 就是一个连接

3 开启事物

​ 4 创键 Customer 对象

​ 5 使用Entitymanager 对象 的persist 方法向数据库添加数据

​ 6 事物提交

​ 7 关闭连接

package cn.lijun.jpa;

import cn.lijun.jpa.entity.Customer;
import org.junit.Test;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;

/**
* @author lijun
* @date 2019/8/14 10:52
*/
public class JpaTest {
  @Test
  public void firstTest(){
//       1 创键一个EntityManagerFactory 对象   使用完关闭
      EntityManagerFactory factory = Persistence.createEntityManagerFactory("myjpa");
//       2 使用工厂对象EntityManagerFactory 就是一个连接
      EntityManager entityManager = factory.createEntityManager();
//       3 开启事物
      EntityTransaction transaction = entityManager.getTransaction();
      transaction.begin();
//       4 创键 Customer 对象
      Customer customer = new Customer();
      customer.setCustName("ruirui");
      customer.setCustLevel("vip");
      customer.setCustSource("网络");
      customer.setCustPhone("123456");
      customer.setCustAddress("懒人中心");
//       5 使用Entitymanager 对象 的persist 方法向数据库添加数据
      entityManager.persist(customer);
//       6 事物提交
      transaction.commit();

//       7 关闭连接
      entityManager.close();
      factory.close();


  }
}

Spring data JPA 快速入门的更多相关文章

  1. Spring Data JPA —— 快速入门

    一.概述 JPA : Java Persistence API, Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中. Spring D ...

  2. Spring Data Redis —— 快速入门

    环境要求:Redis 2.6及以上,javase 8.0及以上: 一.Spring Data Redis 介绍 Spring-data-redis是spring的一部分,提供了在srping应用中通过 ...

  3. Spring Data Solr —— 快速入门

    Solr是基于Lucene(全文检索引擎)开发,它是一个独立系统,运行在Tomcat或Jetty(solr6以上集成了jetty,无需再部署到servlet容器上),但其原生中文的分词词功能不行,需要 ...

  4. Spring Data JPA -1-CRUD入门

    1) 引入jar包支持 <dependency> <groupId>org.springframework.boot</groupId> <artifactI ...

  5. 整合Spring Data JPA与Spring MVC: 分页和排序

    之前我们学习了如何使用Jpa访问关系型数据库.比较完整Spring MVC和JPA教程请见Spring Data JPA实战入门,Spring MVC实战入门. 通过Jpa大大简化了我们对数据库的开发 ...

  6. 整合Spring Data JPA与Spring MVC: 分页和排序pageable

    https://www.tianmaying.com/tutorial/spring-jpa-page-sort Spring Data Jpa对于分页以及排序的查询也有着完美的支持,接下来,我们来学 ...

  7. 【Spring Data 系列学习】Spring Data JPA 自定义查询,分页,排序,条件查询

    Spring Boot Jpa 默认提供 CURD 的方法等方法,在日常中往往时无法满足我们业务的要求,本章节通过自定义简单查询案例进行讲解. 快速上手 项目中的pom.xml.application ...

  8. 【Spring Data 系列学习】了解 Spring Data JPA 、 Jpa 和 Hibernate

    在开始学习 Spring Data JPA 之前,首先讨论下 Spring Data Jpa.JPA 和 Hibernate 之前的关系. JPA JPA 是 Java Persistence API ...

  9. Spring Data Jpa 入门学习

    本文主要讲解 springData Jpa 入门相关知识, 了解JPA规范与Jpa的实现,搭建springboot+dpringdata jpa环境实现基础增删改操作,适合新手学习,老鸟绕道~ 1. ...

随机推荐

  1. react-native学习(一)————使用react-native-tab-navigator创建底部导航

    使用react-native-tab-navigator创建底部Tab导航 1.使用npm安装react-native-tab-navigator npm install react-native-t ...

  2. 安装JDK,并检测JDK是否安装成功

    方法/步骤   首先,我们需要先安装好我们的JDK软件,安装好之后,我们需要对我们的电脑进行环境变量配置的设置,这样我们安装的JDK才能真正起到作用.   第一步:我们需要将光标放在“计算机”上面,然 ...

  3. c 语言 volatile 关键字

    一.前言 1.编译器优化介绍: 由于内存访问速度远不及CPU处理速度,为提高机器整体性能,在硬件上引入硬件高速缓存Cache,加速对内存的访问.另外在现代CPU中指令的执行并不一定严格按照顺序执行,没 ...

  4. 三.通过jenkins对系统的监控(2)

    在这记录下,通过HTTP Request Plugin监控系统的异常.和上一篇原理差不多. 1.首先需要安装HTTP Request Plugin.插件安装好后,在系统设置下面会新增如下配置: 具体有 ...

  5. (61)C# 可枚举类型和迭代器

    一.可枚举类型 枚举器-Enumerator  是一个只读且只能在值序列向前移动的游标 枚举器需要实现下列接口之一 System.Collections.IEnumerator System.Coll ...

  6. 其他信息: 未能加载文件或程序集“WebGrease, Version=1.5.1.25624, Culture=neutral, PublicKeyToken=31bf3856ad364e35”或它的某一个依赖项。找 到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)

    记录一下,发布web时遇到的一些问题. 一.报错信息: 其他信息: 未能加载文件或程序集“WebGrease, Version=1.5.1.25624, Culture=neutral, Public ...

  7. .net Core 在 CentOS7下,报The type initializer for 'Gdip' threw an exception.异常

    .net Core允许在 Centos7 上,使用 System.Draw.Common类库时,报以下错误: "Class":"System.TypeInitializa ...

  8. upc组队赛6 Bumped!【最短路】

    Bumped! 题目描述 Peter returned from the recently held ACM ICPC World finals only to find that his retur ...

  9. vue事件修饰符(once:prev:stop)

    vue事件修饰符(once:prev:stop) stop修饰符  效果如下: 当你鼠标在这个div里的时候,x与y的值:会随着鼠标的变化而变化.但是当鼠标放在stopMoving的时候,x与y的值是 ...

  10. 代码质量管理-Sonar

    1.Sonar 摘要 Sonar 是一个用于代码质量管理的开放平台.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具. 与持续集成工具(例如 Hudson/Jenkin ...