教程简介
本项目内容为Spring Boot教程样例。目的是通过学习本系列教程,读者可以从0到1掌握spring boot的知识,并且可以运用到项目中。如您觉得该项目对您有用,欢迎点击收藏和点赞按钮,给予支持!!教程连载中,欢迎持续关注!
环境
IDE: Eclipse Neon
Java: 1.8
Spring Boot: 1.5.12
数据库:MYSQL
本章简介
通过Spring Boot 教程(一):项目构建,完成Restful API的学习,相信大家已经可以快速搭建一个spring boot的脚手架。
本章将进一步讲解spring boot,结合SpringDataJPA完成数据层访问。
SpringDataJPA是Spring Data的一个子项目,通过提供基于JPA的Repository极大的减少了JPA作为数据访问方案的代码量,你仅仅需要编写一个接口集成下SpringDataJPA内部定义的接口即可完成简单的CRUD操作。
配置
在pom.xml文件中添加如下:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
在applicaiton.properties文件中配置数据库连接信息:
spring.datasource.url = jdbc:mysql://localhost:3306/demo?useUnicode=true&characterEncoding=utf8&characterSetResults=utf8
spring.datasource.username = root
spring.datasource.password = 123456
spring.datasource.driverClassName = com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2ddl.auto=update
spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect
spring.jpa.properties.hibernate.hbm2ddl.auto是hibernate的配置属性:
create:每次加载hibernate时都会删除上一次的生成的表,然后根据你的model类再重新来生成新表,哪怕两次没有任何改变也要这样执行,这就是导致数据库表数据丢失的一个重要原因。
create-drop:每次加载hibernate时根据model类生成表,但是sessionFactory一关闭,表就自动删除。
update:最常用的属性,第一次加载hibernate时根据model类会自动建立起表的结构(前提是先建立好数据库),以后加载hibernate时根据model类自动更新表结构,即使表结构改变了但表中的行仍然存在不会删除以前的行。要注意的是当部署到服务器后,表结构是不会被马上建立起来的,是要等应用第一次运行起来后才会。
validate:每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值。
创建实体和数据访问接口
创建包com.example.demo.model,创建实体User
@Entity
@Table(name = "T_USER")
public class User implements Serializable {
private static final long serialVersionUID = 2711201708013908747L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private Long id;
@Column(name = "name", length = 255)
private String name;
@Column(name = "pass", length = 255)
private String pass;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
}
创建包com.example.demo.domain,创建UserRepository接口实现对该实体的数据访问
public interface UserRepository extends JpaRepository<User, Long> {
User findByName(String name);
User findByNameAndPass(String name, String pass);
@Query("from User u where u.name=:name")
User findUser(@Param("name") String name);
}
UserRepository接口继承了JpaRepository,也就是说UserRepository拥有了JpaRepository接口及父类接口的所有方法实现,所以我们并不需要添加任何数据操作代码就可以完成数据操作,JpaRepository接口对条件查询以及保存集合数据添加了对应的方法。
创建控制器
在com.example.demo.api下面创建User控制器UserController, 用于测试web访问
@RestController
public class UserController {
@Autowired
private UserRepository userDao;
@RequestMapping("/saveUser")
public void save(){
User user = new User();
user.setName("ajay");
user.setPass("123456");
userDao.save(user);
}
@RequestMapping("/delete")
public void delete(String name){
User user = userDao.findByName(name);
userDao.delete(user);
}
@RequestMapping("/updateUser")
public void update(String name){
User user = userDao.findByName(name);
user.setPass("123456789");
userDao.save(user);
}
@RequestMapping("/findByName")
public User findByName(String name){
return userDao.findByName(name);
}
}
程序运行和调试
在Application类中,启动程序。浏览器输入http://localhost:8080/saveUser
http://localhost:8080/findByName?name=ajay
代码:gitee.com/shaojiepeng/SpringBootCourse
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。