前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简单才是美! SpringBoot+JPA

简单才是美! SpringBoot+JPA

作者头像
Mshu
发布2018-10-31 10:53:34
5070
发布2018-10-31 10:53:34
举报
文章被收录于专栏:咸鱼不闲

SpringBoot 急速构建项目,真的是用了才知道,搭配JPA作为持久层,一简到底! 下面记录项目的搭建,后续会添加NOSQL redis,搜索引擎elasticSearch,等等,什么不过时就加什么。

开发工具idea、项目构建gradle、模板引擎thymeleaf

项目构建

1.【new】 -> 【product】 -> 选择Spring Initializr -> 【next】

clipboard.png
clipboard.png

2.填写Group,Artifact,Type ->【next】

clipboard.png
clipboard.png

3.导包

  1. 1.左边选择Web右边勾选Web 2.左边选择SQL右边勾选JPA 3.左边选择SQL右边勾选mysql 4.左边选择Template Engines右边勾选Thymeleaf 5.【next】->【finish】
clipboard.png
clipboard.png

好了 现在的项目结构

clipboard.png
clipboard.png

BootjpaApplication 是项目的启动类 resources/templates/ 文件夹是放页面的 build.gradle 存放jar包坐标

application.properties

代码语言:javascript
复制
spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2ddl.auto=update

@RestController

配置完成,写个controller试试看

代码语言:javascript
复制
@RestController
public class HelloBootController {

    @RequestMapping("helloBoot")
    public String helloBoot(){
        return "Hello Boot-JPA";
    }
}

在BootjpaApplication文件上启动

clipboard.png
clipboard.png

@RestController注解,代替@Controller+@@ResponseBody 那么返回页面就直接用@Controller就好了

现在JPA登场


db

注解和hibernate一样。

代码语言:javascript
复制
@Entity
public class User {

    private long id;
    private String name;
    private String passWord;
    private  String email;

    @Id
    @GeneratedValue
    public long getId() {
        return id;
    }
    。。。。。
  }

现在,就是见证奇迹的时刻!

dao

dao层继承JpaRepository即可

代码语言:javascript
复制
public interface UserRepository extends JpaRepository<User,Long> {
}

什么!这就完了??对,低调

controller

controller层,service层跳过。

代码语言:javascript
复制
@Controller
public class HelloBootController {

    @Autowired
    UserRepository userRepository;

    @RequestMapping("/toHello")
    public String toHello(ModelMap modelMap){
        userRepository.save(new User("Mshu","123456","zhuiqiu95@foxmail.com"));
        List<User> users = userRepository.findAll();
        modelMap.put("users",users);
        return "helloBoot";
    }
}

thymeleaf


至于页面,默认是在resources/templates/下的html,试图解析器已经配置默认配置好的。

代码语言:javascript
复制
前缀:resources/templates/
后缀:html

那我们就在resources/templates/下新建一个html页面 注意<html xmlns:th="http://www.thymeleaf.org " lang="en">引入thymeleaf 用到了thymeleaf语法遍历。

代码语言:javascript
复制
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"  lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<table >
    <tr th:each="user,userState : ${users}">
        <td style="border: 1px solid seagreen" th:text="${user.name}"></td>
        <td style="border: 1px solid seagreen" th:text="${user.passWord}"></td>
        <td style="border: 1px solid seagreen" th:text="${user.email}"></td>
    </tr>
</table>
</body>
</html>

启动,输入地址,回车!

clipboard.png
clipboard.png

精彩回顾

刚刚dao层明明只写了一个接口没有写任何方法,怎么就能调用save(),findAll()呢, 对JPA默认了许多基础增删改查方法,直接调用即可。 怎么写除了默认给出的方法以外怎么写呢,

代码语言:javascript
复制
public interface UserRepository extends JpaRepository<User,Long> {
    User findByName(String name);
}

调用的话直接

代码语言:javascript
复制
User user = userRepository.findByName("Mshu");

那么怎么做的映射的,它怎么知道我的参数name对应表里的name,原来名字一样就可以映射,好像很有道理 没错就那么简单,这种写法太hibernate了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-04-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 项目构建
    • application.properties
      • @RestController
      • 现在JPA登场
        • db
          • dao
            • controller
            • thymeleaf
            • 精彩回顾
            相关产品与服务
            云数据库 Redis
            腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档