ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

spring boot jpa 访问 mysql

2019-05-31 11:56:40  阅读:179  来源: 互联网

标签:return jpa spring public user mysql id


spring boot 访问 mysql
方式二:spring data jpa

为什么使用 jpa :
第一次使用 Spring JPA 的时候,感觉这东西简直就是神器,几乎不需要写什么关于数据库访问的代码一个基本的 CURD 的功能就出来了。

如何使用:
在 pom 文件中引入依赖

<!--jpa -->
<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-commons</artifactId>
        <version>2.1.6.RELEASE</version>
</dependency>

<!-- mysql驱动 -->
<dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
</dependency>

配置数据库:

spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

# JPA 相关配置
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=update

JPA 相关配置

#在 SrpingBoot 2.0 版本中,Hibernate 创建数据表的时候,默认的数据库存储引擎选择的是 MyISAM (之前是 InnoDB)。这个参数是在建表的时候,将默认的存储引擎切换为 InnoDB 用的。

spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect

配置在日志中打印出执行的 SQL 语句信息。

spring.jpa.show-sql=true

每次运行程序,没有表格会新建表格,表内有数据不会清空,只会更新

spring.jpa.hibernate.ddl-auto=update

创建 Entity Dao Service Controller 三层文件:

 entity:
@Entity
@Table(name = "user")
public class JpaUser {

@Id
@GeneratedValue
private Long id;

private String name;

private int age;

private String sex;

public Long getId() {
    return id;
}

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

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public int getAge() {
    return age;
}

public void setAge(int age) {
    this.age = age;
}

public String getSex() {
    return sex;
}

public void setSex(String sex) {
    this.sex = sex;
}

}

Dao
写一个接口 继承 JpaRepository 简单的 CRUD 可以直接使用了

@Repository
public interface JpaUserDao extends JpaRepository<JpaUser,Long> {

}

Service

@Service
public class JpaUserService {

@Autowired
JpaUserDao userDao;

public JpaUser add(JpaUser user){
  return   userDao.save(user);
}

public JpaUser update(JpaUser user){
    return   userDao.save(user);
}

public JpaUser getById(long id){
    return   userDao.findById(id).get();
}

}

Controller

@RestController
@RequestMapping("/jpaUser")
public class JpaUserController {

@Autowired
JpaUserService userService;

@RequestMapping(value = "/add",method = RequestMethod.POST)
public Object addUser(@RequestBody JpaUser user){

    return userService.add(user);
}

@RequestMapping(value = "/update",method = RequestMethod.PUT)
public Object updateUser(@RequestBody JpaUser user){

    return userService.update(user);
}

@RequestMapping(value = "/find",method = RequestMethod.GET)
public Object updateUser(long id){
    return userService.getById(id);
}

}

完成 启动 访问测试

jpa 配置说明:

spring.jpa.hibernate.ddl-auto=create ----每次运行该程序,没有表格会新建表格,有表会删除表重新创建表

spring.jpa.hibernate.ddl-auto=create-drop ----每次程序结束的时候会清空表

spring.jpa.hibernate.ddl-auto=update ----每次运行程序,没有表格会新建表格,表内有数据不会清空,只会更新表结构

spring.jpa.hibernate.ddl-auto=validate ----运行程序会校验数据与数据库的字段类型是否相同,不同会报错

标签:return,jpa,spring,public,user,mysql,id
来源: https://blog.51cto.com/5013162/2403086

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有