IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL语法小结 -> 正文阅读

[大数据]MySQL语法小结

MySQL

启动

1.手动打开服务窗口cmd输入services.msc,找到mysql服务并选择打开
2.右键cmd管理员打开输入 net start mysql
3.右键cmd管理员关闭输入net stop mysql

登录

1.远程连接简写mysql -hip -uroot -p连接目标的密码
2.远程连接详写mysql --host=ip --user=root --password=连接目标的密码
3.本地连接mysql -uroot -p密码

退出

1.退出cmd输入exit
2.退出cmd输入quit

SQL

注释

1.单行注释– 注释内容 或 # 注释内容(mysql 特有)
2.多行注释/* 注释 */

分类

1.DDL(Data Definition Language)用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter 等
2.DML(Data Manipulation Language)用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等
3.DQL(Data Query Language)用来查询数据库中表的记录(数据)。关键字:select, where 等
4.DCL(Data Control Language)用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等

数据类型

简单数据类型

int整数类型
double小数类型 double(5,2) --表示总共5位,小数点后面两位
date日期,只包含年月日,yyyy-MM-dd
datetime日期,包含年月日时分秒 yyyy-MM-dd HH:mm:ss
timestamp时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss 默认本地时间
varchar字符串 varchar(20) —表示最大20个字符

DDL:操作数据库、表

操作数据库:CRUD

C(Create):创建

1.创建数据库create database 数据库名称;
2.创建数据库,判断不存在,再创建create database if not exists 数据库名称;
3.创建数据库,并指定字符集create database 数据库名称 character set 字符集名;
4.小结:创建db4数据库,判断是否存在,并制定字符集为gbkcreate database if not exists db4 character set gbk;

R(Retrieve):查询

1.查询所有数据库的名称show databases;
2.查询某个数据库的字符集:查询某个数据库的创建语句show create database 数据库名称;

U(Update):修改

1.删除数据库drop database 数据库名称;
2.判断数据库存在,存在再删除drop database if exists 数据库名称;

使用数据库

1.查询当前正在使用的数据库名称select database();
2.使用数据库use 数据库名称;

操作表:CRUD

C(Create):创建

1. 语法create table 表名(
列名1 数据类型1,
列名2 数据类型2,

列名n 数据类型n
);
2.注意最后一列,不需要加逗号(,)
3.复制创建create table 表名 like 被复制的表名;

R(Retrieve):查询

1. 查询某个数据库中所有的表名称show tables;
2. 查询表结构desc 表名; --就是有哪些列

U(Update):修改

1. 修改表名alter table 表名 rename to 新的表名;
2. 修改表的字符集alter table 表名 character set 字符集名称;
3. 添加一列alter table 表名 add 列名 数据类型;
4. 修改列名称 类型(1)alter table 表名 change 列名 新列别 新数据类型;
5. 修改列名称 类型(2)alter table 表名 modify 列名 新数据类型;
6. D(Delete):删除alter table 表名 drop 列名;

D(Delete):删除

1.删除表(1)drop table 表名;
2.先判断存在再删除表(2)drop table if exists 表名 ;

DML:增删改表中数据

添加数据

1.语法insert into 表名(列名1,列名2,…列名n) values(值1,值2,…值n);
2.注意1. 列名和值要一一对应。
2. 如果表名后,不定义列名,则默认给所有列添加值
insert into 表名 values(值1,值2,…值n);
3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来

删除数据

1.语法delete from 表名 where 条件
2.注意1. 如果不加条件,则删除表中所有记录。
2. 如果要删除所有记录
- delete from 表名; – 不推荐使用。有多少条记录就会执行多少次删除操作
- TRUNCATE TABLE 表名; – 推荐使用,效率更高 先删除表,然后再创建一张一样的表。

修改数据

1.语法update 表名 set 列名1 = 值1, 列名2 = 值2,… where 条件;
2.注意如果不加任何条件,则会将表中所有记录全部修改。

DQL:查询表中的记录

标准查询

1.语法select
字段列表
from
表名列表
where
条件列表
group by
分组字段
having
分组之后的条件
order by
排序
limit
分页限定

基础查询

1. 多个字段的查询select 字段名1,字段名2… from 表名;
2.全部字段查询select * from 表名;
3.去除重复查询select distinct 字段名1,字段名2… from 表名;
4.起别名as:as也可以省略

条件查询

1.wherewhere子句后跟条件
2.运算符1. > 、< 、<= 、>= 、= 、<>
2. BETWEEN…AND
3. IN( 集合)
4.LIKE:模糊查询
占位符:
_:单个任意字符
%:多个任意字符
5. IS NULL
6. and 或 &&
7. or 或 ||
8. not 或 !

排序查询

1.语法order by 子句
order by 排序字段1 排序方式1 , 排序字段2 排序方式2…
2.排序方式ASC:升序,默认的。
DESC:降序。
3.注意如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。

聚合函数

含义将一列数据作为一个整体,进行纵向的计算
1.count计算个数
SELECT COUNT(DISTINCT column_name) FROM table_name
1. 一般选择非空的列:主键
2. count(*)
2.max计算最大值,语法和上例无差
3.min计算最小值
4.sum计算和
5.avg计算平均值
注意聚合函数的计算,排除null值。
解决方法1. 选择不包含非空的列进行计算
2. IFNULL函数

分组查询

1.语法group by 分组字段;
SELECT Company, OrderNumber FROM Orders ORDER BY Company;
2.注意1. 分组之后查询的字段:分组字段、聚合函数
2. where 和 having 的区别?
1. where 在分组之前进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果,则不会被查询出来
2. where 后不可以跟聚合函数,having可以进行聚合函数的判断。

分页查询

1.语法limit 开始的索引,每页查询的条数;
2.计算索引公式公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数
3.例子– 每页显示3条记录

SELECT * FROM student LIMIT 0,3; – 第1页

SELECT * FROM student LIMIT 3,3; – 第2页

SELECT * FROM student LIMIT 6,3; – 第3页
4.注意limit 是一个MySQL"方言",不同数据库语言有不同实现方式

约束

概念和分类

概念对表中的数据进行限定,保证数据的正确性、有效性和完整性。
1.主键约束primary key
2.非空约束not null
3.唯一约束unique
4.外键约束foreign key

主键约束

1.注意1. 含义:非空且唯一
2. 一张表只能有一个字段为主键
3. 主键就是表中记录的唯一标识
2.创建表时创建create table stu(
id int primary key,-- 给id添加主键约束
name varchar(20)
);
3.删除主键ALTER TABLE stu DROP PRIMARY KEY;
4.创建完表之后添加主键ALTER TABLE stu MODIFY id INT PRIMARY KEY;
注意列数据要符合主键要求才能添加
5.创建表时为主键添加自增长create table stu(
id int primary key auto_increment,-- 给id添加主键约束
name varchar(20)
);
6.删除自增长ALTER TABLE stu MODIFY id INT;
7.之后添加自增长ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;

外键约束

概念foreign key,让表于表产生关系,从而保证数据的正确性。
1.创建表时添加外键语法:
create table 表名(

外键列
constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)
);
–需要一个外键列
2. 删除外键ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
3. 创建表之后,添加外键ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);

级联操作

概念需要依托于外键添加
1. 添加级联操作ALTER TABLE 表名 ADD CONSTRAINT 外键名称
FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE
2. 分类1. 级联更新:ON UPDATE CASCADE
2. 级联删除:ON DELETE CASCADE
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-10-09 16:21:04  更:2021-10-09 16:22:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:20:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码