[Mysql] 的基础知识和sql 语句.教你速成(上)——逻辑清晰,涵盖完整

news2024/12/22 19:39:45

目录

前言

上篇的内容概况

下篇的内容概况

 数据库的分类

关系型数据库

常见的关系型数据库系统

非关系型数据库

1. 键值对数据库(Key-Value Stores)

特点:

常见的键值对数据库:

2. 文档数据库(Document Stores)

特点:

常见的文档数据库:

3. 列族数据库(Column-Family Stores)

特点:

常见的列族数据库:

4. 图数据库(Graph Databases)

特点:

常见的图数据库:

Mysql 常见的数据类型

数值类型

字符串类型

日期类型

sql 语句

首先是数据库的操作

建立数据库

展示数据库

删除数据库

使用数据库

基础的表的操作

展示所有表

建立表

查看表的结构

删除表

 修改表

表的增删查改

新增数据

查询数据(****)

全列查询

指定列查询

查询[字段为表达式]的查询

别名(as)

去重(distinct)

 排序 (order by)

 条件查询(where)

比较运算符

逻辑运算符

分页查询

查询语句的书写和执行顺序(****)

修改数据(update)

删除(delet)

上篇总结


前言

OK,笔者知道笔者这篇博客写完的时候,很多人已经考完数据库了,但是笔者还是要写,因为笔者还没考完捏

Mysql 作为一个开源的,易于安装和配置的,有着图形化工具的关系型数据库管理系统软件, 非常适合我们入门数据库,所以笔者会介绍Mysql 的基础知识和 sql 语句

上篇的内容概况

 数据库的分类, Mysql的数据类型,基础的sql 语句

包括数据库的操作,表的操作 ,基础的 CRUD管理和组织表的数据

下篇的内容概况

数据库的约数,聚合查询,联合查询

索引,事物,Mysql 的 JDBC 编程

不想看前面的废话直接目录空降即可

 数据库的分类

数据库分 关系型数据库 和  非关系型数据库   而我们的Mysql 就是前者

关系型数据库

所谓 关系型数据库 ,就是通过 我们说的 "表" 来 组织数据的,每个表都有自己的"行" 和 "列"

然后通过 sql 语句 来进行管理和操作,我们一般期末考试也就是考 sql 语句和画ER 图

(个人观点别骂我)不过有一说一,画ER 图是真没什么屁用,软件工程的项目需求几乎不需要成本去改,一天一个样,你画图纸除了骗骗未来啥都不知道的甲方和领导,真的有tm 一点用吗??????

常见的关系型数据库系统
  • PostgreSQL
  • Oracle Database
  • Microsoft SQL Server
  • SQLite

非关系型数据库

这个笔者没有学习过,不太了解, 大致理解是通过键值对和文档来组织数据,所以下面内容来自网络

1. 键值对数据库(Key-Value Stores)

键值对数据库使用简单的键值对存储数据,类似于字典或哈希表。每个键唯一标识一个值,这种模型非常适合快速查找和大规模分布式存储。

特点:
  • 数据通过键来访问,操作非常快速。
  • 适用于缓存、会话存储和简单数据存储等场景。
  • 灵活性高,但不适合复杂查询。
常见的键值对数据库:
  • Redis
  • Amazon DynamoDB
  • Riak
2. 文档数据库(Document Stores)

文档数据库使用文档来存储数据,通常以 JSON、BSON 或 XML 格式表示。文档可以包含复杂数据结构,包括嵌套的文档和数组。

特点:
  • 数据结构灵活,适用于半结构化和非结构化数据。
  • 支持丰富的查询和索引功能。
  • 常用于内容管理系统、用户数据存储等场景。
常见的文档数据库:
  • MongoDB
  • CouchDB
  • Amazon DocumentDB
3. 列族数据库(Column-Family Stores)

列族数据库使用列族(column families)来组织数据,类似于关系型数据库的表,但列族中的列是动态的,可以根据需要添加。数据以列为中心进行存储和查询。

特点:
  • 高效地存储和查询大规模数据。
  • 适用于数据分析、时间序列数据和大数据应用。
常见的列族数据库:
  • Apache Cassandra
  • HBase
  • ScyllaDB
4. 图数据库(Graph Databases)

图数据库使用图结构来存储数据,节点表示实体,边表示实体之间的关系。这种模型非常适合处理复杂的关系和连接查询。

特点:
  • 自然地表示和查询复杂关系。
  • 适用于社交网络、推荐系统和网络分析等场景。
常见的图数据库:
  • Neo4j
  • Amazon Neptune
  • JanusGraph

Mysql 常见的数据类型

常见的 数据类型就是 数值类型, 字符串类型,还有日期类型;

数值类型

tinyint小整数,范围:-128 到 127 或 0 到 255
smallint较小整数,范围:-32768 到 32767 或 0 到 65535
mediumint中等大小整数,范围:-8388608 到 8388607 或 0 到 16777215
int/integer标准整数,范围:-2147483648 到 2147483647 或 0 到 4294967295
bigint大整数,范围:-9223372036854775808 到 9223372036854775807 或 0 到 18446744073709551615
decimal(m,d)定点数,精确到小数点后 m 位,总共 d 位
float单精度浮点数,4 字节
double双精度浮点数,8 字节
bit位字段类型,可存储位值

 笔者练习的时候 常用 int,declmai,double 其他都是在书上看了几眼

字符串类型

数据类型描述
char(m)固定长度字符串,最多 255 个字符
varchar(m)可变长度字符串,最多 65535 个字符
tinytext非常小的文本字符串,最多 255 个字符
text

 如上,基本都是笔者从书上汇总来的

日期类型

date日期值,格式:yyyy-mm-dd
datetime日期和时间值,格式:yyyy-mm-dd hh:mm
timestamp时间戳,格式:yyyy-mm-dd hh:mm,自动更新

 有时候可以配合 now() 函数使用就是了

sql 语句

好的,终于来到了sql 语句速成 这一块了 基本思路就是 CRUD

首先是数据库的操作

建立数据库

create database (if not exists)  数据库的名字  charset utf8;

 记得手动指定编码方式为 utf8,不然无法使用中文

展示数据库

show databases;

删除数据库

drop database if exists 数据库名字;

使用数据库

use 数据库的名字

管理表之前要使用数据库

基础的表的操作

展示所有表

show tables;

建立表

create table 表的名字(你自己觉得) (id int,name varchar(20));

在表的名字后面 打括号,写上你想要的 列名 数据类型,用逗号分隔,我这里随便举了个例子给你看看


查看表的结构

desc 表名

 效果如图,会显示表的结构

删除表

drop table 表的名字

 修改表

alter table

这个有点多,不好举例 

表的增删查改

以下操作大概就是重点了, CRUD!!!

CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写
怕有人不知道所以我提一嘴

新增数据

insert into 表名 (指定列,如果不写就是默认所有列)  values (插入数据,要符合每一列的数据类型)

例如

insert into student values(1,'张三');

可以一次性插入很多数据

insert into student values(1,'张三'),(2,'李四').(3,'王五');

查询数据(****)

通过查询操作,我们将穿插一些子句语法

全列查询

顾名思义,可以查询表中的所有列和行

select * from 表名

我的老师告诉我,这个在实际生产中要慎用,如果数据库存在大量数据,容易占用资源造成损失,当然了我们平时自己的数据库那是随便用了.

*号代表所有

指定列查询

为了放置我上述的情况产生,我们要指定列去查询

select (列名,用逗号隔开) from 表名
查询[字段为表达式]的查询

请看图

 这是一个样例, 我可以查询 三科成绩之和(这就是一个表达式)

select id,name,chinese+math+english from exam_result;

效果如上图,可以得到表达式结果 

别名(as)

 

我们可以给三科之和去一个别名

语法如下

select id,name,chinese+math+english as total from exam_result;

 效果如下

在需要的列后面 + as 新名字,as 可以省略,但推荐加上去 

去重(distinct)

如果有重复的数据,可以通过如下语法去重

select DISTINCT (指定列) from 表名

太简单了就不举例演示了

 排序 (order by)

记住这两个要点

1. 没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序
2. NULL 数据排序,视为比任何值都小,升序出现在最上面,降序出现在最下面

语法如下,以上面的exam_result 表为例子 查询姓名和数学成绩,并且排序

 select id,math from exam_result order by  math desc;

   order by (指定列) desc/asc;
-- ASC 为升序(从小到大)
-- DESC 为降序(从大到小)
-- 默认为 ASC

效果如图

如果没有指定 是升序还是降序,默认升序

可以配合别名使用,比如把三科成绩排序

select id,name,chinese+math+english as total from exam_result order by total desc;

 条件查询(where)

在讲解之前,必须知道  逻辑运算符和比较运算符

因为在 MySQL 中,where 子句用于指定选择查询中的条件,以过滤符合特定条件的记录。逻辑运算符和比较运算符用于在 where 子句中构建条件表达式。

比较运算符

                                                             等于column = value
<>                                                             不等于column <> value
!=                                                    不等于(同 <>column != value
>                                                             大于column > value
<                                                               小于column < value
>=                                                       大于等于column >= value
<=                                                       小于等于column <= value
BETWEEN                                           在范围内column BETWEEN value1 AND value2
NOT BETWEEN                                不在范围内column NOT BETWEEN value1 AND value2
IN                                                  在集合中column IN (value1, value2, ...)
NOT IN                                       不在集合中column NOT IN (value1, value2, ...)
LIKE                                       模糊匹配column LIKE pattern
NOT LIKE                          不模糊匹配column NOT LIKE pattern
IS NULL                         是空值column IS NULL
IS NOT NULL          不是空值column IS NOT NULL
逻辑运算符
AND                                                      逻辑与condition1 AND condition2
OR                                                        逻辑或condition1 OR condition2
NOT                                               逻辑非NOT condition

 我给标红的运算符举例,其他的大伙应该也会不用我说了

还是那张表,查询数学成绩在60-90 的

select name,math from exam_result where math between 60 and 90;

或者这么写

select name,math from exam_result where math >= 60 and math < 90;

 模糊匹配

-- % 匹配任意多个(包括 0 个)字符

-- _ 匹配严格的一个任意字符
记住这个就好了

总的来说,写条件查询就像英语写定语从句,多写几次就会了

分页查询

在数据库查询中,分页查询 (limit) 是一种非常常见的技术,尤其是在处理大量数据时。分页查询通过限制每次返回的记录数量,可以有效地管理和显示数据。

-- 从 0 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
-- 从 s 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;
-- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

比如,查询前三个的 id 和 name ,按 id 排序

select id,name from exam_result order by id limit 3;

 可以看到,null  在首位,也确实只有前三个

其他的读者自己去练习吧

查询语句的书写和执行顺序(****)

看了那么多例子,很难记全东西, 所以记忆sql 语句需要一些逻辑

比如,顺序

书写顺序

select -- from --where--group--having--order by--limit ;

执行顺序

from -- where--group by--having--select--order by--limit;

查询还没结束哦,只不过我实在是写不动了,上述都是基础,还有进阶的聚合查询和联合查询,笔者以后更!!!!!

修改数据(update)

过了最多最全的查询,来到修改,这个是修改表的数据,而不是修改表的结构.

UPDATE table_name SET column = expr [, column = expr ...]
 [WHERE ...] [ORDER BY ...] [LIMIT ...]

语法如上

还是举例来看,还是那张表

 我要修改孙十万的70的语文成绩改成90;

update exam_result set chinese=90 where name ='孙权';

效果如下

把总成绩倒数前三的人的 数学加1分;

首先,找到倒数前三

select id,name,chinese+math+english as total from exam_result  
order by total limit 1,3;

然后,加分

update exam_result set math=math+1 
order by chinese+math+chinese limit 4;

效果如图

 好的修改就到这里,也不难说实话

删除(delet)

删除数据

语法如下

DELETE FROM  table_name [WHERE ...] [ORDER BY ...] [LIMIT.....];

举例,把孙悟空这一行从表上删了

delet from exam_result where name='孙悟空';

 把表的数据删完

delete from exam_result;

注意,这和删表

drop table exam_result;

有区别的, 一个是把里面的数据删了容器还在,后者是直接把锅砸了

看图

 一个是表空了,一个是没有表了

删除写到这

上篇总结

总结就是写博客是最好的复习方式,我不是在写笔记,笔者是真的希望有人能看懂和学会!!!!!!!!

笔者花了大约3小时写完了上篇,主要是介绍了数据库的基础知识和一些基础的sql 语句

包括数据库的操作,表的操作 ,基础的 CRUD管理和组织表的数据

下篇,笔者写的是

数据库的约束,聚合查询,联合查询

索引,事物,Mysql 的 JDBC 编程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1843437.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBootWeb 篇-入门了解 Vue 前端工程的创建与基本使用

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 基于脚手架创建前端工程 1.1 基于 Vue 开发前端项目的环境要求 1.2 前端工程创建的方式 1.2.1 基于命令的方式来创建前端工程 1.2.2 使用图形化来创建前端工程 1.…

最新源支付系统源码 V7版全开源 免授权 附搭建教程

简介&#xff1a; 最新源支付系统源码_V7版全开源_免授权_附详细搭建教程_站长亲测 YPay是专为个人站长打造的聚合免签系统&#xff0c;拥有卓越的性能和丰富的功能。它采用全新轻量化的界面UI&#xff0c;让您能更方便快捷地解决知识付费和运营赞助的难题。同时&#xff0c;…

【服务器04】之【Navicat连接阿里云】

通过前三篇文章&#xff0c;现在我们测试可以连接数据库了 点开桌面的 接下找来的主机 地址在以下 登录阿里云 登陆账号后 点击控制台 输入RDS 弹出新页面&#xff0c;并点击运行中的 1 点管理 复制外网地址 鼠标靠近就会出现复制图标 用户名 和 密码 是注册阿里云的高权限账…

Cocos引擎加密方案解析

据2023年数据显示&#xff0c;Cocos引擎全球游戏市场的占有率约为20%&#xff0c;国内手游占有率约为40%&#xff0c;在国内手游市场中&#xff0c;不少热门游戏均为Cocos引擎研发&#xff0c;如《捕鱼达人》、《梦幻西游》、《剑与远征》等。 而在近年来国内火热的小游戏赛道…

Linux内核开发-替换内核

0.前言 上一章&#xff08;点击返回上一章&#xff09;提到如何编译内核源码&#xff0c;本章主要介绍如何将编好的内核替换已有的内核。 1. 替换内核 第1步&#xff1a;查看当前内核版本 cat /proc/version第2步&#xff1a; 查看机器上的内核信息 grep menuentry /boot/…

北森发布2024中国企业校园招聘白皮书,解读校招5大核心要素

随着新一轮技术革命和产业变革的到来&#xff0c;市场竞争日益加剧&#xff0c;企业也正面临着前所未有的挑战与机遇。在这一变革的新时代&#xff0c;人才成为企业在竞争中保持优势、稳步发展的关键因素。当下&#xff0c;青年人才正以其敏锐的时代感知、创新思维和敏捷的新技…

如何在springboot项目中引入knife4j接口文档

开发框架&#xff0c;帮助后端开发人员做后端接口测试 knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案 引入依赖 <dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</artifactId>&…

Java基础16(集合框架 List ArrayList容器类 ArrayList底层源码解析及扩容机制)

目录 一、什么是集合&#xff1f; 二、集合接口 三、List集合 四、ArrayList容器类 1. 常用方法 1.1 增加 1.2 查找 int size() E get(int index) int indexOf(Object c) boolean contains(Object c) boolean isEmpty() List SubList(int fromindex,int …

UniApp 开发微信小程序教程(二):下载安装微信开发者工具

文章目录 一、微信开发者工具简介二、下载安装微信开发者工具1. 下载微信开发者工具步骤&#xff1a; 2. 安装微信开发者工具Windows 系统&#xff1a;Mac 系统&#xff1a; 3. 配置微信开发者工具登录微信开发者工具&#xff1a;新建项目&#xff1a; 4. 预览和调试预览&#…

电商还存在错位竞争空间吗?

“上链接试了&#xff0c;十几分钟&#xff0c;成本5块的东西卖1块5了。”今年618前期&#xff0c;某个电商平台上线了自动跟价功能&#xff0c;有一个卖家尝试了一会儿之后赶紧关了。 又一个618&#xff0c;平台、商家、消费者们又迎来了一次狂欢。只是与往年不同的是&#x…

从2-3-4树开始理解红黑二叉树(JAVA代码手撸版)

经典的红黑二叉树在新增/删除数据时维持自平衡始终对应着一个2-3-4 树。本文只关注2-3-4 对应的经典红黑二叉树。 暂时不考虑 2-3 树对应的左倾红黑二叉树。 背景知识 2-3-4 树简介 一棵 2-3-4 树的结点分为 内部结点 (internal nodes) 和 叶子结点 (leaf nodes) &#xff0c;…

KVB交易平台:国内三大交易所(上海、深圳、北京)的概要与分析

概述&#xff1a; 上海证券交易所&#xff08;上交所&#xff09;、深圳证券交易所&#xff08;深交所&#xff09;和北京证券交易所&#xff08;北交所&#xff09;是中国大陆三大主要证券交易所。以下是对这三个交易所的比较分析&#xff1a; 一、基本概况 1. 上海证券交易所…

零基础入门AI:四步快速搭建本地的编程助手

由于种种原因&#xff0c;小伙伴们在写代码时&#xff0c;不一定能用上Github Copilot&#xff1b;或者由于代码安全的原因&#xff0c;不能使用外网的编程助手。今天我就介绍一种利用开源大语言模型在本地搭建编程助手的方案&#xff1a; IDE插件&#xff1a;Continue本地开源…

DB9母头接口定义485

在通信技术中&#xff0c;DB9接口广泛应用于串行通信&#xff0c;尤其是在RS232和RS485标准中。虽然DB9接口最常见于RS232通信&#xff0c;但通过适当的引脚映射&#xff0c;它也可以用于RS485通信。本文将详细介绍如何定义和使用DB9母头接口进行RS485连接。 DB9母头接口简介 …

探索FlowUs息流:个人和团队知识管理解决方案|FlowUs稳定保障你的笔记安全无忧

FlowUs息流&#xff1a;稳定运营保障你的笔记安全无忧 在知识管理工具的选择上&#xff0c;稳定性是用户最关心的问题之一。FlowUs息流以其稳定的运营记录&#xff0c;为用户提供了一个可靠的工作环境。我们深知&#xff0c;一个知识管理平台的稳定性直接影响到团队的生产力和…

echarts引入百度地图vue3(大屏项目中缩放点偏移到左上角,解决代码在最后)

实际开发中的问题&#xff0c;遇到了大屏做了自适应&#xff0c;为非标准文档流之后&#xff0c;在缩放时不是以鼠标当前位置缩放的&#xff0c;而是偏移到左上角。 向百度地图提了工单也没解决&#xff0c;同一套适应方案用cesium地图时缩放没问题&#xff1a; 先看看效果&am…

动态规划——达拉崩吧

1、题目链接 174. 地下城游戏 2、题目分析 假如说我们正向推状态转移方程&#xff0c;很难推出来&#xff0c;因为这道题有“加血”的说法&#xff0c;只能依靠后面的值判断前面所需要的血量&#xff0c;也就是说&#xff0c;如果正向的dp表示从起点出发&#xff0c;到达&…

CSS新手入门笔记【导入方法、选择器介绍、选择器优先级、属性详细介绍、盒子模型】

目录 一、目的与优势二、CSS导入方式三、语法结构四、选择器类型基本选择器组合选择器伪类与伪元素属性选择器 六、选择器优先级总结 六、CSS属性1. 字体与文本属性2. 背景属性3. 尺寸与盒模型属性4. 布局与定位5. 列表样式6. 边框与轮廓7. 文本装饰与效果8. 动画与过渡9. 伪类…

多模块存储器

随着计算机技术的发展&#xff0c;处理的信息量越来越多&#xff0c;对存储器的速度和容量要求也越来越高&#xff1b;而且随着CPU性能的不断提高、IO设备数量不断增加&#xff0c;导致主存的存取速度已经称为了整个计算机系统的性能瓶颈。这就要求我们必须提高主存的访问速度。…

Linux基础命令大全(详解版)

Linux基础命令&#xff08;详解版&#xff09; 文章目录 Linux基础命令&#xff08;详解版&#xff09;1.Linux的目录结构**2.Linux路径的描述方式**3.Linux命令基础格式4.ls命令 隐藏文件、文件夹5.pwd命令6.cd命令 特殊路径符7.mkdir命令 文件操作命令8.touch命令9.cat命令10…