mysql中常用命令完整大全 适用于mysql8.0

news2025/7/16 14:09:18

关于安装部分就去看其他人的一些文章即可网上太多,这篇文章主要就是记录本人的一些关于mysql操作上的笔记。

mysql中常用命令

    • 1.登录数据库
    • 2.查看当前数据库
    • 3.创建数据库
    • 4.删除数据库
    • 5.创建表user基于以下条件
    • 6.使用主键约束
    • 7.指定非空
    • 8.唯一约束
    • 9.默认约束
    • 10.设置表数值默认自动增加
    • 11.查看表的字段名或者是否为空
    • 12.查询更加详细表结构
    • 13.修改表名
    • 14.修改字段数据类型
    • 15.修改字段名
    • 16.添加字段
      • 1.对添加的字段进行约束,如添加不为空
      • 2.对表的第一列添加一个字段
      • 3.在表的指定列后添加一个字段
      • 4. 删除字段
      • 5.修改字段的排列位置
    • 17.删除数据
    • 文本字符类型
    • 18.查询数据
      • 1.查询所有字段
      • 2.查询指定字段
      • 3.查询多个字段
      • 4.查询指定记录
      • 5.查询关于YYjHhHHJG6
      • 6.查询价格小于300的worknu
      • 7.带in关键词的查询
      • 8.查询所有worknu不等104,163的记录
      • 9.查询100-200之间的范围
      • 10.like字符匹配查询
      • 11.多条件查询AND
      • 12.OR多条件查询
      • 13.查询不重复数据
      • 14.对查询结果进行排序
      • 15.分组查询
      • 16.查询结果显示头几行
      • 17.聚合查询
        • 1.count 统计列中包含的行数
        • 2.avg返回某列中的平均值
        • 3.max返回某列的最大值
        • 4.min返回某列最小值
        • 5.sum返回某列的和
    • 19.表别名
      • 1.字段别名
    • 20.使用正则查询
        • 1.查询work中c开头的记录
        • 2.查询work中c结尾的记录
        • 3.查询字符串中任意一个包含字符"."
        • 4.查询连续出现次数的字符
    • 20.为指定表和插入数据
      • 同时插入多条数据
    • 21.更新数据update
      • between AND 更新从多少到多少的数值
    • 22.删除数据
      • 1.删除user1表中id为30-100的数据
      • 2.删除表中所有的记录
    • 21.创建一个用户
    • 22.删除用户
    • 23.创建普通索引
    • 24.创建唯一索引
    • 25.创建主键索引
    • 26.创建视图
    • 27.多表视图
    • 28.修改视图
    • 29.更新视图
    • 30.删除视图

1.登录数据库

mysql -u root -p

2.查看当前数据库

show databases

3.创建数据库

create database abcd;
OK
时间: 0.003s

如果当前数据库已经存在,则会提示已存在无法创建

create database abcd;
1007 - Can’t create database ‘abcd;’; database exists
时间: 0s

4.删除数据库

drop database abcd
OK
时间: 0.008s

5.创建表user基于以下条件

员工所在部门员工id员工姓名员工的工资
deptldidnamesalary
varchar(15)int(15)varchar(15)int(10)

使用之前已经创建数据库abcd

use abcd;

create table user(
	`deptld` varchar(15),
	`id` int(15),
	`name` varchar(15),
	`salary` int(10)
)

6.使用主键约束

primary key
比如我要设置id为主键就在表创建的时候在末尾新增
primary key (id)
多个主键的话就是直接在括号中新增即可
primary key (id,name)
如果我需要使用外键也就是连接另一个表的数据进行关联时
比如我需要在user2中,让外键deptld关联到deptld2的主键id中,
那么我可以这样操作
在创建表时在末尾写下这段
constraint deptld2 foreign key(deptld) references user(id)

7.指定非空

约束一个字段值不为空
not null

create table user(
	`deptld` varchar(15) not null,
	`id` int(15),
	`name` varchar(15),
	`salary` int(10)
)

8.唯一约束

unique
确保一列或几列不能出现重复值,但是可以为空,perimary key外键不能为空,unique允许为空,但不能重复

create table user(
	`deptld` varchar(15) not null,
	`id` int(15) unique,
	`name` varchar(15),
	`salary` int(10)
)

9.默认约束

default + 值
默认当前数值为女、或者男

create table user(
	`deptld` varchar(15) not null,
	`id` int(15) unique,
	`name` varchar(15),
	`salary` int(10) default 2500
)

10.设置表数值默认自动增加

auto_increment
每新增一个数值,默认自增加一可用在例如id之类的数据上

create table user(
	`deptld` varchar(15) not null,
	`id` int(15) auto_increment,
	`name` varchar(15),
	`salary` int(10) default 2500
)

11.查看表的字段名或者是否为空

describe user
简写
desc user
在这里插入图片描述

12.查询更加详细表结构

show create table user

在这里插入图片描述

13.修改表名

alter table user rename user1;

14.修改字段数据类型

alter table user1 modify name varchar(30);
修改前varchar是15,修改后变成varchar30
在这里插入图片描述

15.修改字段名

alter table user1 change name name1 varchar(15);
在这里插入图片描述

16.添加字段

alter table user1 add work varchar(15);
在这里插入图片描述

1.对添加的字段进行约束,如添加不为空

alter table user1 add workid int(8) not null;

在这里插入图片描述

2.对表的第一列添加一个字段

alter table user1 add worknu int(15) first;
在这里插入图片描述

3.在表的指定列后添加一个字段

alter table user1 add t11 int(15) after id;
在这里插入图片描述

4. 删除字段

alter table user1 drop t11;

在这里插入图片描述

5.修改字段的排列位置

alter table user1 modify id int(15) first;
将id移动到表的第一个位置
在这里插入图片描述
alter table user1 modify work varchar(15) after id;
将work移动到id后面
在这里插入图片描述

17.删除数据

drop table if exists abc;

文本字符类型

18.查询数据

1.查询所有字段

select * from user1
在这里插入图片描述

2.查询指定字段

select work from user1
在这里插入图片描述

3.查询多个字段

select work,worknu from user1;

在这里插入图片描述

4.查询指定记录

select work,worknu from user1 where worknu 7;
在这里插入图片描述

5.查询关于YYjHhHHJG6

select work,worknu from user1 where work=‘YYjHhHHJG6’
在这里插入图片描述

6.查询价格小于300的worknu

select work,worknu from user1 where worknu < 300

7.带in关键词的查询

worknu 104,163
select work,worknu from user1 where worknu in (104,163) order by worknu在这里插入图片描述

8.查询所有worknu不等104,163的记录

select work,worknu from user1 where worknu not in (104,163) order by work
在这里插入图片描述

9.查询100-200之间的范围

select work,worknu from user1 where worknu between 100 and 200
在这里插入图片描述

10.like字符匹配查询

like 可以对字符开头a%,%a结尾,中间%a%
select work,worknu from user1 where work like ‘b%’
在这里插入图片描述

11.多条件查询AND

查询user1中id大于30且小于300,name1中间有c的字符,且salary大于300,并显示id,workid,name1,salary

select id,workid,name1,salary from user1 where id>30 and id<300 and name1 like ‘%c%’ and salary>300;
在这里插入图片描述

12.OR多条件查询

只要满足其中一个条件即可查询

select id,workid,name1,salary from user1 where id=246 OR id=170

在这里插入图片描述

13.查询不重复数据

select distinct workid from user1
在这里插入图片描述

14.对查询结果进行排序

order by desc降序排序
order by asc升序排序
多列排序,先按照work排序再按照id排序
select id,work from order by work ,id;

15.分组查询

对workid进行分组,相同id为一组,并计算其中总数

select workid,COUNT(*) as total from user1 GROUP BY workid
在这里插入图片描述

16.查询结果显示头几行

limit 4就是显示前四行
limit 5,10就是从第5行开始显示到第10行

select * from user1 LIMIT 5,10
在这里插入图片描述

17.聚合查询

1.count 统计列中包含的行数

select count(id) from user1;
统计id中包含最大的数据
在这里插入图片描述

2.avg返回某列中的平均值

select avg(salary) from user1;
统计salary中的平均数据
在这里插入图片描述

3.max返回某列的最大值

select max(salary) from user1;
返回salary中最大值
在这里插入图片描述

4.min返回某列最小值

select min(salary) from user1;
返回最小值
在这里插入图片描述

5.sum返回某列的和

select sum(salary) from user1;
返回salary中的总值
在这里插入图片描述

19.表别名

select * from user1 as u where u.worknu =535;
u就是表的别名直接用u代替user1使用即可查询到表内的信息
在这里插入图片描述

1.字段别名

select work AS w,worknu as wn from user1 as u where u.worknu = 94
在这里插入图片描述

20.使用正则查询

具体正则可参考以下文章
正则表达式常用字符匹配列表

1.查询work中c开头的记录

select * from user1 where work REGEXP ‘^c’
在这里插入图片描述

2.查询work中c结尾的记录

select * from user1 where work REGEXP ‘c$’
在这里插入图片描述

3.查询字符串中任意一个包含字符"."

select * from user1 where work REGEXP ‘x.c’
在这里插入图片描述

4.查询连续出现次数的字符

a{3,} a最少出现3次
a{1,3} a最少出现1次,最多出现3次

select * from user1 where workid regexp ‘7{1,3}’
在这里插入图片描述

20.为指定表和插入数据

insert into user1 (id,work,worknu,deptld,name1,salary,workid) VALUES (1,‘adc’,222,‘abcdeer’,‘Dem Kevi’,22222,12345)
在这里插入图片描述

同时插入多条数据

insert into user1 (id,work,worknu,deptld,name1,salary,workid) VALUES (1,‘adc’,222,‘abcdeer’,‘Dem Kevi’,22222,12345),(2,‘abcd’,333,‘abcddd’,‘Kce ve’,2222,11111)

21.更新数据update

将id为52的数据更新,将worknu更新成666,salary更新成8888

update user1 set worknu=666,salary=8888 where id =52;
在这里插入图片描述

between AND 更新从多少到多少的数值

更新id为20-30,将salary数值变成8888
UPDATE user1 set salary=8888 where id BETWEEN 20 and 30;
在这里插入图片描述

22.删除数据

DELETE from user1 where id =52;
删掉user表中id为52的数据
在这里插入图片描述

1.删除user1表中id为30-100的数据

DELETE from user1 where id BETWEEN 30 and 100;
在这里插入图片描述

2.删除表中所有的记录

delete from user1;

21.创建一个用户

创建一个用户,用户名user10,密码gkbb123 主机名localhost

create user ‘user10’@‘localhost’ IDENTIFIED by ‘gkbb123’
在这里插入图片描述

22.删除用户

删除user10

drop user ‘user10’@‘localhost’

在这里插入图片描述

23.创建普通索引

create index a on user1(work);
查询索引
show index from user1
在这里插入图片描述

24.创建唯一索引

create unqiue index abc on user1(wrok)
注意:这里面的字段里面不能有重复值不然的话无法创建唯一索引

25.创建主键索引

create table w(id int PRIMARY key)
show index from w;查询主键
在这里插入图片描述

alter table w drop primary key;
删除主键

在这里插入图片描述

26.创建视图

在user1表中创建一个名为a的视图,并只显示work和workid
create view a as select work,workid from user1
SELECT * from a
查看视图中的数据
在这里插入图片描述

27.多表视图

在st1表中和st2表中同时创建一个视图f1,同时显示id,name,class

create view f1 (id,name,class) as SELECT st1.id,st1.name,st2.class FROM st1,st2 where st1.id=st2.id
注意:需要保证两个表的列数相同不然无法创建成功
SELECT * from f1
查询创建的表
在这里插入图片描述
查看视图的基本内容
describe f1
在这里插入图片描述
show table status like ‘f1’
查看视图基本信息
在这里插入图片描述
show create view f1
查看视图的详细信息
在这里插入图片描述

28.修改视图

create or replace view f1 as select * from user1
将f1视图的信息源变成user1
在这里插入图片描述
alter view f1 as select name from st1
alter也可以对视图内部的显示字段进行修改
在这里插入图片描述

29.更新视图

update f1 set name=5
视图内的name字段全变成5
在这里插入图片描述
insert into f1 values (11)
对视图进行插入操作
在这里插入图片描述
delete from f1 where name=5
将视图里面的name=5的记录全删掉
在这里插入图片描述

30.删除视图

drop view if exists f1;
删除f1视图
在这里插入图片描述

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

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

相关文章

物联网时代下的5G融合定位,可以实现哪些功能?

5G具有高带宽、高频谱&#xff08;毫米波&#xff09;、多天线阵列等特性&#xff0c;通过提升无线定位算法的能力、室内数字系统建设、完善5G定位服务流程以及与其它定位技术和平台的结合&#xff0c;可提高5G定位精度。室内高精度定位服务为5G定位扩展到更多应用场景和领域构…

C++:类和对象:运算符重载

前言&#xff1a; 运算符重载概念&#xff1a;对已有的运算符重新进行定义&#xff0c;赋予其另一种功能&#xff0c;以适应不同的数据类型。 1&#xff1a;加号运算符重载 对于内置的数据类型&#xff0c; 编译器知道如何运算&#xff0c;可以很直观的得到结果 int a 10; …

西瓜书-支持向量机

支持向量机 支持向量:距离超平面最近的这几个训练样本点。 支持向量机的核心思想是最大化间隔γ2∣∣w∣∣\gamma \frac{2}{||w||}γ∣∣w∣∣2​。 求极大转换为求极小&#xff0c;转化为凸规划问题。 对偶问题 利用拉格朗日乘子法&#xff0c;对于不等式约束&#xff0c;…

安全网络身份认证系统的设计与实现

本文章源码地址&#xff1a;https://gitee.com/sukels/shirohttps://gitee.com/sukels/shiro 摘 要 随着互联网的飞速发展,Web应用的安全问题日益凸显。为了保护Web应用中用户和企业的敏感信息,认证授权加密已经成为了Web应用中不可缺少的部分。但是随之而来是巨大的代码工作…

欧科云链半年报解读Final

欧科云链半年报解读&#xff1a;净利润同比扭亏为盈&#xff0c;区块链大数据等创新业务贡献新增长曲线 日前&#xff0c;欧科云链控股&#xff08;01499.HK&#xff09;发布2022年度截至9月30日止的六个月中期报告。报告显示&#xff0c;公司在2022年4月1日至2022年9月30日实现…

【idea插件】EasyCode介绍与使用

1.简介 EasyCode是idea的一个插件,主要功能是代码生成,类似的插件还有jpa support EasyCode是idea的一个插件&#xff0c;可以采用图形化的方式对数据的表生成entity,controller,service,dao,mapper……无 需任何编码&#xff0c;简单而强大。可以大幅度的提高开发效率.下面来…

UG/NX二次开发Siemens官方NXOPEN实例解析—2.7 DiameterSymbol

列文章目录 UG/NX二次开发Siemens官方NXOPEN实例解析—2.1 AssemblyViewer UG/NX二次开发Siemens官方NXOPEN实例解析—2.2 Selection UG/NX二次开发Siemens官方NXOPEN实例解析—2.3 Selection_UIStyler UG/NX二次开发Siemens官方NXOPEN实例解析—2.4 File2Points UG/NX二次…

第三章:远程登陆Linux系统-[实操篇]

一&#xff1a;为什么需要远程登陆Linux 1.1示意图 1.2说明 说明: 公司开发时候&#xff0c; 具体的情况是这样的 1) linux 服务器是开发小组共享的. 2) 正式上线的项目是运行在公网的. 3) 因此程序员需要远程登录到 centos 进行项目管理或者开发. 4) 画出简单的网络拓扑…

Vue3——路由的query参数和命名路由以及默认插槽slot的使用

这里主要在message页面组件和detail页面组件介绍 看一个案例&#xff0c;当一个二级路由下面又有许多个不同的跳转页面的时候&#xff0c;比如下图的about/message/detail , 需要分别展示多条信息&#xff0c;这里不能给每一条信息都配置一个组件&#xff0c;那样当信息的数量…

RocketMQ-RocketMQ 系统架构以及消息的概念

文章目录一、RocketMQ的消息模型1、RocketMQ的基础消息模型&#xff0c;一个简单的Pub/Sub模型2、RocketMQ 扩展后的消息模型3、RocketMQ的部署模型二、RocketMQ的系统架构2、Consumer3、Name Server3.1、路由注册3.2、路由剔除3.3、路由发现3.4、Client 对 NameServer选择策略…

Spring5框架总结学习(从入门到进阶)-AOP

文章目录AOP1、基本概念2、底层原理3、底层原理实现4、AOP&#xff08;术语&#xff09;5、准备工作6、基于注解实现AOP 1、基本概念 面向切面编程可用对各个业务逻辑各个部分进行隔离 2、底层原理 AOP底层使用动态代理 有2种情况动态代理 有接口 使用JDK动态代理无接口 使…

ffmpeg编译安装

ffmpeg编译安装前言一、下载ffmpeg二、编译安装2.1 Linux编译ffmpeg2.2 Windows编译ffmpeg总结前言 Fmpeg是一套可以用来记录、转换数字音频、视频&#xff0c;并能将其转化为流的开源计算机程序。采用LGPL或GPL许可证。它提供了录制、转换以及流化音视频的完整解决方案。它包含…

154. SAP UI5 Smart Table 和 Smart Filter Bar 的联合使用方法介绍

本教程第 147 个步骤,我们介绍了 SAP UI5 Smart Table 控件的用法: SAP UI5 应用开发教程之一百四十七 - SAP UI5 SmartTable 控件的使用介绍如下图所示: 本步骤我们在 Smart Table 本身的基础上再进一步,学习如何将 Smart Table 配合 Smart Filter Bar 共同使用。 先看一…

JDK之强软弱虚引用

Java中强软弱虚引用的整体架构&#xff1a; 强引用 当内存不足&#xff0c;JVM开始垃圾回收&#xff0c;对于强引用的对象&#xff0c;就算是出现了OOM也不会对该对象进行回收&#xff0c;死都不收。 强引用是我们最常见的普通对象引用&#xff0c;只要还有强引用指向一个对象…

Fabric.js 元素被遮挡的部分也可以操作

本文简介 点赞 关注 收藏 学会了 题目&#xff1a; 当两个元素有部分重叠时&#xff0c;选中底层元素后&#xff0c;想通过被盖住的部分移动元素&#xff0c;该如何实现&#xff1f; 其实 Fabric.js 已经提供了相应的 API 去完成上面的需求了。但直到今天&#xff0c; Fabr…

动态内存开辟+柔性数组

C/C中程序内存区域划分 &#xff08;数据段就是静态区&#xff09; C/C程序内存分配的几个区域: 1.栈区 (stack): 在执行函数时&#xff0c;函数内局部变量的存储单元都可以在栈上创建&#xff0c;函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集…

linux系统中裸机实现RTC的基本方法

大家好&#xff0c;今天主要和大家聊一聊&#xff0c;如何显示RTC实时时钟的方法。 目录 第一&#xff1a;RTC实时时钟简介 第二&#xff1a;利用SNVS_LP的SRTC的具体配置方法 第三&#xff1a;初始化RTC对应的代码 第一&#xff1a;RTC实时时钟简介 在高端芯片中&#xff0…

Docker管理面板Crane开源了!

导读数人云容器管理面板 Crane 开源啦&#xff01;Crane 包含着数人云工程师对 Docker 最新技术的热爱和实践。希望借助开源社区的力量&#xff0c;让 Crane 完善自身&#xff0c;更好地成长起来&#xff0c;让更多的国内用户体验并参与到最新的容器技术中。在 Docker 内置 Swa…

Java HashMap

HashMap 是一个散列表&#xff0c;它存储的内容是键值对(key-value)映射。 HashMap 实现了 Map 接口&#xff0c;根据键的 HashCode 值存储数据&#xff0c;具有很快的访问速度&#xff0c;最多允许一条记录的键为 null&#xff0c;不支持线程同步。 HashMap 是无序的&#x…

2023年天津理工大学中环信息学院专业课考试具体安排

天津理工大学中环信息学院2023年高职升本科专业课考试时间地点及防疫须知 一、考试时间地点 考试时间&#xff1a;2022年12月29日上午。 具体考试时间以准考证上显示的为准。 考生可提前半小时入场&#xff0c;考试开始&#xff08;铃声&#xff09;后&#xff0c;禁止入场&…