SpringBoot基础(三)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot基础(三)相关的知识,希望对你有一定的参考价值。

参考技术A

大家好,一直以来我都本着 用最通俗的话理解核心的知识点, 我认为所有的难点都离不开 「基础知识」 的铺垫

「大佬可以绕过 ~」

本节给大家讲讲 「Java的SpringBoot框架」 , 之前我们学习的都是java的基础知识和底层提供的一些能力,我们日常工作都是在写接口。在我们在产品开发中,一般我们都会选择比较稳定的框架来帮我们加速开发,不会自己去造轮子,而在java众多框架中,spring框架表现的非常好,大部分公司都会首选它作为开发框架,而至今,大部分企业都是以 springboot 来构建项目了~

上期我们讲解了springboot中的 http请求处理 以及涉及到的几个注解。后台服务始终绕不开数据的开发,我们需要把用户产生的数据落地到数据库。本期,将带大家学习一下springboot中的 数据库处理 , 我们将学习目前市面上比较火的 Mybatis 框架, 它是一个 ORM 框架, 我将分为 三个小节 去讲解,现在用的比较多的数据库是 Mysql , 它是一个 开源 关系型 数据库, 这一节将带大家快速入门 Mysql 。最近github可能会被墙,所以我把源码放到了国内gitee上,本节我们依然使用上期的代码

如果你是mac用户,推荐使用 homebrew 安装, 它是mac软件包管理工具,如果你还没安装, 可以到这个官网去安装 https://brew.sh/index_zh-cn, 安装好后执行命令:

安装好后,它会列出启动命令,设置root密码命令,复制运行即可

如果你是windows用户, 可以直接去mysql官网下载安装, 安装好后运行即可

工欲善其事,必先利其器。目前市面上可视化工具很多,目前比较火的是 Navicat ,推荐使用,功能也丰富,界面也比较美观。平时开发中,推荐大家多使用工具,因为很多繁琐的事情,点点按钮就结束了,不用去敲黑乎乎的命令了。

安装好后,我们点击左上角的链接,链接到我们的数据库,链接成功后,右击链接名称,点击新建数据库。

多说一点, 在 生产环境 中,数据库操作,我们一般没有编辑操作,通常只有查询数据的操作, 一般用的都是云产品, 比如阿里云的 Rds ,因为维护数据库服务的成本太大了,安全性也不高,所以 生成环境 中的库一般都是用的云产品。如果你是管理员,对账号一定要做权限,和账号分配。

之前我们提到mysql是 关系型(RDBMS) 数据库, 我们需要理解几个关键术语:

如果你看的有点懵逼,没关系,这不影响我们成为 crud body , 本节只是带大家快速入门,不会涉及太多专业领域知识,不要慌~

终于进入正题了,下面我们学习一下mysql的 sql 编写。我们用 Navicat 新建一张表, 点击我们刚刚创建的库,点击表, 然后点击右边 绿色 加号,就可以新建了。 然后会跳出新建字段的界面,输入我们的字段就好, 字段 意思就是数据的一个属性, 这里我们以用户角色表为例,我就不一一带大家新建字段了,这里直接导sql,可以参考, 我也是用工具新建的,创建完的表想复制sql给别人,可以点击右边的 DDL 查看创建表的 sql

表我们插好了,怎么往里边查数据呢? 有两种方式:

我们最常用的就是表的sql操作了,所以我们重点学习数据操作相关的 sql 语法

插入记录:

我们平常业务开发用的最多就是 查询 操作了,往往复杂的 sql 也都是在这里产生, sql 优化也是优化查询

sql 的语法语义化还是比较友好的,我们查询数据就是 select xxx ,在哪查就是 from , 查哪个就是 where ,很容易理解, 所以不用去背它,要去理解它,多写就熟悉了

这里给大家介绍常用的两种:

这种有弊端,就是 distinct 必须跟在字段

name 进行分组, GroupBy 后边可以跟多个字段,当是多个字段时,需要满足多条件

对于数据 去重 , 有时候当数据量很大的时候,我们用 sql 查询会非常吃力,我们可以在代码层面上做处理,因为程序计算比较快

本节到此就结束了,我们主要讲了 Mysql 数据库的使用,建议大家多自己练习练习,不要去背语句,要去理解它,适当的做些总结, 最新的代码已经同步到仓库了

有了 sql 基础之后,我们再学习 MyBatis 框架就相对简单了,下期带大家正式学习它~

以上是关于SpringBoot基础(三)的主要内容,如果未能解决你的问题,请参考以下文章

SpringBoot进阶之整合Shiro鉴权框架(三)

SpringBoot 之基础学习篇.

三天讲透SpringBoot-初识基础使用

SpringBoot2.X基础教程:SpringBoot整合MyBatis附源码

SpringBoot集成SpringSecurity(三注解方式配置权限)

SpringBoot入门到精通-SpringBoot入门