栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringBoot整合JPA的实例代码

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot整合JPA的实例代码

JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。

JPA 的目标之一是制定一个可以由很多供应商实现的API,并且开发人员可以编码来实现该API,而不是使用私有供应商特有的API。

JPA是需要Provider来实现其功能的,hibernate就是JPA Provider中很强的一个,应该说无人能出其右。从功能上来说,JPA就是Hibernate功能的一个子集。

添加相关依赖

添加spring-boot-starter-jdbc依赖:


      org.springframework.boot
      spring-boot-starter-data-jpa
      
    

添加MySQL连接类和连接池类:

  
      mysql
      mysql-connector-java
      runtime
     

配置数据源,在application.properties文件配置:

spring:
 datasource:
  driver-class-name: com.mysql.jdbc.Driver
  url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&characterSetResults=utf8
  username: root
  password: 123456

 jpa:
  hibernate:
   ddl-auto: update # 第一次简表create 后面用update
  show-sql: true

注意,如果通过jpa在数据库中建表,将jpa.hibernate,ddl-auto改为create,建完表之后,要改为update,要不然每次重启工程会删除表并新建。

创建实体类

通过@Entity 表明是一个映射的实体类, @Id表明id, @GeneratedValue 字段自动生成

@Entity
public class Account {
  @Id
  @GeneratedValue
  private int id ;
  private String name ;
  private double money;

... 省略getter setter
}

Dao层

数据访问层,通过编写一个继承自 JpaRepository 的接口就能完成数据访问,其中包含了几本的单表查询的方法,非常的方便。值得注意的是,这个Account 对象名,而不是具体的表名,另外Interger是主键的类型,一般为Integer或者Long

public interface AccountDao extends JpaRepository {
}

Web层

在这个栗子中我简略了service层的书写,在实际开发中,不可省略。新写一个controller,写几个restful api来测试数据的访问。

@RestController
@RequestMapping("/account")
public class AccountController {

  @Autowired
  AccountDao accountDao;

  @RequestMapping(value = "/list", method = RequestMethod.GET)
  public List getAccounts() {
    return accountDao.findAll();
  }

  @RequestMapping(value = "/{id}", method = RequestMethod.GET)
  public Account getAccountById(@PathVariable("id") int id) {
    return accountDao.findOne(id);
  }

  @RequestMapping(value = "/{id}", method = RequestMethod.PUT)
  public String updateAccount(@PathVariable("id") int id, @RequestParam(value = "name", required = true) String name,
  @RequestParam(value = "money", required = true) double money) {
    Account account = new Account();
    account.setMoney(money);
    account.setName(name);
    account.setId(id);
    Account account1 = accountDao.saveAndFlush(account);

    return account1.toString();

  }

  @RequestMapping(value = "", method = RequestMethod.POST)
  public String postAccount(@RequestParam(value = "name") String name,
 @RequestParam(value = "money") double money) {
    Account account = new Account();
    account.setMoney(money);
    account.setName(name);
    Account account1 = accountDao.save(account);
    return account1.toString();

  }


}

通过postman请求测试,代码已经全部通过测试。

源码下载:https://github.com/forezp/SpringBootLearning

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/146366.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号