Mysql 容易忘的 sql 指令总结

news2025/4/24 12:56:34

目录

一、操作数据库的基本指令

二、查询语句的指令

1、基本查询语句

2、模糊查询

3、分支查询

4、 分组查询

5、分组查询

6、基本查询总结:

7、子查询

8、连接查询

三、MySQL中的常用函数

1、时间函数

2、字符串函数

3、聚合函数

4、运算函数

         四、表的操作指令

五、权限管理的指令

六、SQL 优化中使用的指令

(1)索引的使用

1、创建索引

2、查看索引

3、测试索引

4、删除索引

(2)存储引擎的相关指令

1、查看表引擎

2、修改表引擎


一、操作数据库的基本指令

-- 连接mysql数据库

-- mysql -u用户名 -p密码

mysql -uroot -p123456

-- 查看所有数据库

show databases;

-- 创建数据库 默认编码为utf8

-- create database 数据库名;

create database java11;

-- 创建数据库 指定编码格式

-- create database 数据库名 character set 编码格式;

create database java111 character set 'gbk';

-- 创建数据库 判断数据库不存在再创建

create database if not exists java111 character set 'gbk';

-- 查看数据库的创建信息

-- show create database 数据库名;

show create database java11;

-- 删除数据库

-- drop database 数据库名;

drop database java11;

-- 删除数据库 如果存在才删除

-- drop database if exists 数据库名;

drop database if exists java11;

-- 修改数据库

-- alter database 数据库名 character set '字符集'

alter database java111 character set 'utf8';

-- 查看当前使用的数据库

select database();

-- 连接数据库

-- use 数据库名;

use java111;

二、查询语句的指令

1、基本查询语句

-- 查询不是10部门的员工信息

select * from t_employees where DEPARTMENT_ID <> 10; -- <> 也是 != 的意思

select * from t_employees where DEPARTMENT_ID != 10;

-- 查询工资在 10000 到 15000之间的员工信息

-- between 起始值 and 终止值 包含起始值和终止值

-- 写法1: select * from t_employees where salary > 10000 and salary < 15000;

-- 写法2: select * from t_employees where SALARY BETWEEN 10001 and 14999;

2、模糊查询

-- 模糊条件(like not like)

-- 占位符 % 表示0个或多个任意字符 _表示一个任意字符

-- 查询所有员工姓氏中包含'S'的员工信息

select * from t_employees where last_name like 's'; -- 此时的like相当于=号

select * from t_employees where last_name like '%S%'; -- 查询所有员工姓氏中'S'开头的员工信息 select * from t_employees where last_name like 'S%';

-- 查询所有员工姓氏中第二个字母为'S'的员工信息

select * from t_employees where last_name like '_S%';

-- 查询所有员工姓氏中'S'开头并且姓氏的长度至少7个字符的员工信息

select * from t_employees where last_name like 'S%' and last_name like '%___%';  -- 7个_

-- 查询所有员工姓氏中不包含'S'的员工信息

select * from t_employees where last_name not like '%S%';

3、分支查询

-- 分支查询,相当于构建一个字段

/*

case when 条件1 then 结果1

        when 条件2 then 结果2

        when 条件3 then 结果3

        ...

        else 不满足条件的结果

end 别名

*/

-- 查询所有的员工信息,工资按照登记划分(12000以上A类、10000以上B类、8000以上C类、5000以上D类、其他E类)

select last_name,salary, case when salary > 12000 then 'A类'

                                                when salary > 10000 then 'B类'

                                                when salary > 8000 then 'C类'

                                                when salary > 5000 then 'D类'

                                                else 'E类'

                end salGrade from t_employees;

4、 分组查询

-- 语法1: select 列1,列2,.. from 表名 group by 分组字段

-- 语法2: select 列1,列2,.. from 表名 group by 分组字段 having 分组条件

-- 查询2018年的各渠道的消费数量

select CHANNEL_CODE,count(1) from user_order uo group by channel

having ORDER_DATE ='2018-01-01';

-- 注意:上述语句会报错,因为having 的分组条件是基于查询的列来进行筛选的,select 查询的列中并没有 order_date 这一列,所以就不能在 having 中判断该条件。

-- 正确写法

select CHANNEL_CODE,count(1) from user_order uo where ORDER_DATE ='2018-01-01'

group by channel

5、分组查询

-- 分页查询

-- 语法1: select 列1,列2,.. from 表名 limit m m表示查询的条数(默认从第一条开始查询)

-- 语法2: select 列1,列2,.. from 表名 limit n,m n表示起始位置(默认从0开始),m表示查询的条数

-- 总结:

当前页currentPage、每一页条数pageSize -- 分页公式 (currentPage-1)*pageSize,pageSize

6、基本查询总结:

/*

SQL的 编写顺序 :select from where group by having order by limit

SQL的 执行顺序 :①from ②where ③group by ④having ⑤select ⑥order by ⑦limit

*/

7、子查询

-- 子查询:在一个查询语句中嵌套另个查询语句,一般都在 from 或者 where 之后使用。

/*

子查询用在where从句后面:

        子查询的结果为:

                单行单列:可以直接比较

                多行单列: in >all大于最大 <all小于最小 >any 大于最小 <any 小于最大

        子查询用在from从句后面: 多行多列:注意:必须要取别名

*/

8、连接查询

连接查询的分类:

        内连接 特点:左表中的数据必须要与右表的中的数据关联,才会被查询出来。

                语法1:select 列1,列2,... from 左表,右表 where 左表.关联字段 = 右表.关联字段;

                语法2:select 列1,列2,... from 左表 [inner] join 右表 on 左表.关联字段 = 右表.关联字段;

        外连接

                左外连接

                        特点:左表中的数据如果没有与右表关联,那么也会被查询出来,右表中的数

                                   据用null表示

                        语法:select 列1,列2,... from 左表 left join 右表 on 左表.关联字段 = 右表.关联字段;                 右外连接

                        特点:右表中的数据如果没有与左表关联,那么也会被查询出来,左表中的数据用

                                   null表示

                        语法:select 列1,列2,... from 左表 right join 右表 on 左表.关联字段 = 右表.关联字

                                   段;

        全连接

                合并查询

                        UNION:合并两张表的数据,并且会去重

                        UNION ALL:合并两张表的数据,不会去重

                        注意:合并两个查询结果,要保证两个查询的列数相同,数据类型要兼容

三、MySQL中的常用函数

1、时间函数

-- 获取系统当前的日期时间

select sysdate();

-- 获取系统当前的日期时间

select now();

-- 获取系统当前的日期 select curdate();

-- 获取系统当前的时间 select curtime();

-- 获取时间的年份 select year('2021-02-22');

-- 计算两个时间的差值 select datediff(sysdate(),'2021-10-20');

-- 在指定的日期上添加指定的天数 select adddate(sysdate(),25);

2、字符串函数

-- 拼接字符串

select concat('hello','world','!');

-- 查询所有员工的姓名

select CONCAT(last_name," ",first_name) name from t_employees;

-- 将'hello,java!!' 改为 'hello,mysql!!'

select insert('hello,java!!',7,4,'mysql');

-- 将字符串变成小写形式

select lower('HELLO');

-- 将字符串变成大写形式

select upper('hello');

-- 截取字符串

select substr('hello,java!!!',7,4);

-- 判断字符串中是否有该子串

select instr('hello,java!!!','java');

3、聚合函数

-- sum函数

-- 查询公司一个月要支付的员工费用(工资+绩效)

select sum(salary + salary * ifnull(COMMISSION_PCT,0)) from t_employees;

-- avg函数

-- 查询公司的员工平均工资 select avg(salary) from t_employees;

-- max函数

-- 查询公司的最高工资 select max(salary) from t_employees;

-- min函数

-- 查询公司最低的工资 select min(salary) from t_employees;

-- count函数 表示所有列 count函数只会统计指定的列不为null的列

-- 查询公司的总人数

select count(1) from t_employees; select count(1) from t_employees;

-- 注意:在使用 min() 和 max() 查询的时候,不要再查询其他字段的数据,因为这样查询没有意义,它会返回这一列数据的第一条数据

-- select min(salary),last_name from t_employees; -- 不正确写法

4、运算函数

-- 将运算结果已百分比形式展示,round 保留小数位

select concat(ROUND(IFNULL(a.price,0) / (IFNULL(a.total_price,0))*100,2),'%') priceRate

from user_order a;

-- ifnull() 和 is null 的区别

ifnull() 是一个函数,用来判断空值然后给一个默认值,一般用于 select 查询字段。

is null 是用来判断该值是否为空,一般用于 where 判断条件。

四、表的操作指令

-- 查询当前数据所有表

-- show tables;

-- 查看表结构

-- desc 表名

desc emp;

-- 创建表

/*

create table 表名( 字段名1 字段类型 [约束], 字段名2 字段类型 [约束], 字段名3 字段类型 [约束], ... );

*/

create table student(

        ID int primary key auto_increament, -- 主键并且自增 => 主键:非空+唯一

        NAME varchar(25) default 'cxk', -- 设置默认值

        AGE int not null, -- 不能为空

        ADDR varchar(25) unique -- 唯一 可以为空

)

insert into user (ID,AGE,ADDR) values (1,20,null)

-- 删除表

-- 语法: drop table 表名;

-- 语法: drop table if exists 表名;

drop table if exists student;

-- 修改表

-- 修改表名

-- 语法:alter table 表名 rename 新的表名

alter table student rename user;

-- 添加列

-- 语法:alter table 表名 add 字段名 数据类型

alter table student add birthday datetime;

-- 修改列数据类型

-- 语法: alter table 表名 modify 字段名 数据类型

alter table student modify birthday date;

-- 删除列

-- 语法:alter table 表名 drop 字段名

alter table student drop age;

-- 修改列名

-- 语法: alter table 表名 change 旧字段名 新字段名 数据类型

alter table student change name sname varchar(50);

五、权限管理的指令

-- 创建用户

-- 语法:create user 用户名 identified by 用户密码

create user 'cxk' identified by '123456';

-- 用户授权

-- 语法:grant 权限名称(select、update、insert、alter、create..) on 数据库.数据表 to 用户

 grant all on . to 'cxk'; grant select on java11.emp to 'cxk';

-- 回收权限

-- 语法:revoke 权限名称(select、update、insert、alter、create..) on 数据库.数据表 from 用户 revoke select on java11.emp from 'cxk';

-- 删除用户

-- 语法: drop user 用户名

drop user 'cxk';

六、SQL 优化中使用的指令

(1)索引的使用

1、创建索引

-- 主键索引:设置为主键默认创建

-- 普通索引(单字段)

-- create index 索引名称 on 表名(字段名)

-- 普通索引(多字段)

-- create index 索引名称 on 表名(字段1,字段2)

-- 唯一索引

-- create unique index 索引名称 on 表名(字段名)

-- 全文索引

-- create fulltext index 索引名称 on 表名(字段名)

-- 示例:为 if_member 列创建索引

create index member on user_order(if_member)

2、查看索引

show create table table_name; -- 展示表的创建信息

show indexes from table_name;

show keys from table_name;

3、测试索引

explain select * from 表名 where 条件;

4、删除索引

drop index index_name on 表名;

(2)存储引擎的相关指令

1、查看表引擎

-- 查看表的创建信息

show create table tablename;

-- 查看该数据库下每张表的引擎

SHOW TABLE STATUS FROM db_name;

-- 查看该数据库下指定数据表的引擎

SHOW TABLE STATUS FROM db_name WHERE NAME='table_name';

2、修改表引擎

alter table table_name engine=innodb;

alter table table_name engine=myisam;

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

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

相关文章

使用element中el-cascader级联选择器实现省市区街道筛选(非动态加载)

<template><el-form ref"form" :model"form" label-width"80px"><el-form-item label"地址:" prop"addressList"><el-cascaderv-model"form.addressList":props"props":options&q…

NModbus-一个C#的Modbus协议库实现

NModbus-一个基于C#实现的Modbus通信协议库 最近在学习C#的时候&#xff0c;因为之前做过环保设备时使用C做过环保设备采集使用到了Modbus协议&#xff0c;当时看了一下基于C语言开发的libmodbus库。所以特意搜索看了一下C#下有什么Modbus协议库&#xff0c;在Github上面找了一…

代数结构与图论

文章目录 图的基本概念欧拉图与哈密顿图树平面图代数系统群与环格与布尔代数 图的基本概念 图的阶&#xff1a;图中的顶点数 &#xff0c;n 个顶点被称为 n 阶图零图&#xff1a;一条边都没有 平凡图&#xff1a;一阶零图基图&#xff1a;将有向图的各条有向边改成无向边所得到…

基于CNN神经网络的手写字符识别实验报告

作业要求 具体实验内容根据实际情况自拟&#xff0c;可以是传统的BP神经网络&#xff0c;Hopfield神经网络&#xff0c;也可以是深度学习相关内容。 数据集自选&#xff0c;可以是自建数据集&#xff0c;或MNIST&#xff0c;CIFAR10等公开数据集。 实验报告内容包括但不限于&am…

Gin 源码深度解析及实现

介绍 什么是 gin &#xff1f; 一个轻量级高性能 HTTP Web 框架。 Introduction | Gin Web Framework (gin-gonic.com) Gin 是一个用 Go (Golang) 编写的 HTTP Web 框架。 它具有类似 Martini 的 API&#xff0c;但性能比 Martini 快 40 倍。 为什么使用 gin &#xff1f; In…

个人财务管理软件Money Pro mac功能特点

Money Pro mac是一款专为Mac用户设计的个人财务管理软件&#xff0c;具有全面的账户管理、智能的预算规划、强大的投资分析、丰富的报表和图表、安全的数据保护以及易于使用的界面设计等特点。 Money Pro mac功能和特点 全面的账户管理&#xff1a;支持多种账户类型&#xff0…

git 常用操作合集

✨专栏介绍 在当今数字化时代&#xff0c;Web应用程序已经成为了人们生活和工作中不可或缺的一部分。而要构建出令人印象深刻且功能强大的Web应用程序&#xff0c;就需要掌握一系列前端技术。前端技术涵盖了HTML、CSS和JavaScript等核心技术&#xff0c;以及各种框架、库和工具…

【Matlab】BP 神经网络时序预测算法

资源下载&#xff1a; https://download.csdn.net/download/vvoennvv/88681507 一&#xff0c;概述 BP 神经网络是一种常见的人工神经网络&#xff0c;也是一种有监督学习的神经网络。其全称为“Back Propagation”&#xff0c;即反向传播算法。BP 神经网络主要由输入层、隐藏层…

二叉树的中序遍历,力扣

目录 题目地址&#xff1a; 题目&#xff1a; 解题方法&#xff1a; 解题分析&#xff1a; 解题思路&#xff1a; 代码实现&#xff1a; 注&#xff1a; 代码实现&#xff08;递归&#xff09;&#xff1a; 代码实现&#xff08;迭代&#xff09;&#xff1a; 题目地址&#xf…

独立站的个性化定制:提升用户体验的关键

随着电子商务的竞争加剧&#xff0c;用户体验成为了企业赢得市场的关键因素之一。独立站作为企业品牌形象和产品展示的重要平台&#xff0c;其个性化定制的程度直接影响着用户体验。本文将探讨独立站的个性化定制如何提升用户体验&#xff0c;并通过代码示例说明实现个性化定制…

项目中使用Java中List.subList()的注意事项

使用介绍 在Java中&#xff0c;subList是List接口的一个方法&#xff0c;用于获取原始列表的子列表 方法的声明如下 List<E> subList(int fromIndex, int toIndex);fromIndex&#xff1a;起始索引&#xff08;包括&#xff09;toIndex&#xff1a;结束索引&#xff08…

DrGraph原理示教 - OpenCV 4 功能 - 颜色空间

前言 前段时间&#xff0c;甲方提出明确需求&#xff0c;让把软件国产化。稍微研究了一下&#xff0c;那就转QT开发&#xff0c;顺便把以前的功能代码重写一遍。 至于在Ubuntu下折腾QT、OpenCV安装事宜&#xff0c;网上文章很多&#xff0c;照猫画虎即可。 这个过程&#xff0…

【JVM】一篇通关JMM内存模型

JMM内存模型 1. 原子性1-1. 问题分析1-2. 问题解决 2. 可见性2-1. 问题分析2-2. 问题解决 3. 有序性3-1. 问题分析3-2. 问题解决 4. CAS与原子性5. synchronized 优化 1. 原子性 很多人将【java 内存结构】与【java 内存模型】傻傻分不清&#xff0c;【java 内存模型】是 Java…

zookeeper之集群搭建

1. 集群角色 zookeeper集群下&#xff0c;有3种角色&#xff0c;分别是领导者(Leader)、跟随着(Follower)、观察者(Observer)。接下来我们分别看一下这三种角色的作用。 领导者(Leader)&#xff1a; 事务请求&#xff08;写操作&#xff09;的唯一调度者和处理者&#xff0c;保…

ARCGIS PRO SDK 访问Geometry对象

一、Geometry常用对象 二、主要类 1、ReadOnlyPartCollection&#xff1a;Polyline 和 Polygon 使用的 ReadOnlySegmentCollection 部件的只读集合&#xff0c;属性成员&#xff1a;​ 名字描述Count获取 ICollection 中包含的元素数。TIEM获取位于指定索引处的元素。Spatial…

STM32——F407定时器概述

1 定时器分类 定时器类型数量位号位宽时钟捕获/比较输出DMA请求计数互补输出基本2TIM6,TIM716bitAPB1-有递增-通用2TIM2,TIM532bitAPB14通道有递增、递减、中心对齐-通用2TIM3,TIM432bitAPB14通道有递增、递减、中心对齐-通用1TIM916bitAPB14通道有递增-通用2TIM10、TIM1116bi…

CorelDRAW2024新功能有哪些?CorelDRAW2024最新版本更新怎么样?

CorelDRAW2024新功能有哪些&#xff1f;CorelDRAW2024最新版本更新怎么样&#xff1f;让我们带您详细了解&#xff01; CorelDRAW Graphics Suite 是矢量制图行业的标杆软件&#xff0c;2024年全新版本为您带来多项新功能和优化改进。本次更新强调易用性&#xff0c;包括更强大…

Cisco模拟器-企业网络部署

某企业园区网有&#xff1a;2个分厂&#xff08;分别是&#xff1a;零件分厂、总装分厂&#xff09;1个总厂网络中心 1个总厂会议室&#xff1b; &#xff08;1&#xff09;每个分厂有自己的路由器&#xff0c;均各有&#xff1a;1个楼宇分厂网络中心 每个楼宇均包含&#x…

{MySQL}索引事务和JDBC

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、索引1.1索引是什么1.2作用1.3代码 二、事务2.1什么是事务2.2使用 三.JDBC总结 前言 接着上次&#xff0c;继续讲下MySQL 提示&#xff1a;以下是本篇文章正…

QT中的信号与槽的讲解

文章目录 信号及其特点槽及其特点代码演示标准信号与标准槽函数方式一方式二 自定义信号和槽connect()函数信号和槽函数存在函数重载的情况下Qt的信号槽机制注意事项 信号及其特点 信号&#xff1a;是一种特殊的函数&#xff0c;又称信号函数&#xff0c;俗称信号&#xff0c;…