MySQL常用基础 - 小白必看

news2025/1/9 1:14:16

MySQL数据库基本操作

在这里插入图片描述

一、DDL

概念:是一个数据定义语言

该语言部分包括:

1、对数据库的常用操作

  • 创建数据库:

  • 1、create database 数据库名 (直接删除)

  • 2、create database if not exists 数据库名 (判断数据库是否存在,不存在则创建)

  • 3、create database if not exists 数据库名 charset =字符编码 (在2的基础上加上数据库的字符编码)

    create database if not exists demo charset =utf8
    
  • 切换数据库:use 数据库名

    use demo
    
  • 删除数据库:

    1、drop database 数据库 (直接删除)

    2、drop database if exists 数据库名(判断是否存在数据库,存在即删除)

    drop database if exists demo
    
  • 查看所有数据库

    show databases

  • 修改数据库编码

    ALTER DATABASE 数据库名 CHARSET 字符编码;

    ALTER DATABASE demo CHARSET utf8;
    

    ALTER DATABASE 数据库名 character set 字符编码;

    alter database newer2 character set utf8
    

2、对表结构的常用操作

  • 创建表:

格式:create table if not exists 表名(

字段名1 字段类型(长度)约束,

字段名2 字段类型(长度)约束,

字段名3 字段类型(长度)约束,

字段名4 字段类型(长度)约束

);

 create table if not exists 表名(

字段名1 类型 (长度) 约束条件 comment '字段说明' ,

字段名2 类型 (长度) 约束条件 comment '字段说明' ,

字段名3 类型 (长度) 约束条件 comment '字段说明' 

)表的一些设置;

数据类型:

数据类型关键字
整型int integer
浮点类型double, float
decimal(6,2)整个小数长5位,小数点不占位,小数是两位(9999.99)
字符串型char:定长,char(2)最长存储2个字符,无论有没有2个字符,都是占2个字符
varchar:可变长度,varchar(10) 最长可以保存10个字符
日期类型date(2010-10-11) 或time(19:22:22) 、datetime(2010-10-11 19:22:33)

对表的一些其他操作:

  • 查看当前数据库的所有表名称:
show tables;
  • 查看表结构:
desc 表格;
  • 删除表:
drop table 表名
  • 查询表创建语句:
show create table  表名
  • 修改表结构
alter table 表名
  • 添加列add
alter table 表名 add 字段名 数据类型;
  • 修改列数据类型 modify
alter table 表名 modify 字段名 数据类型;
  • 修改列名和类型 change
alter table 表名 change 旧字段名 新的字段名 数据类型;
  • 删除列
alter table 表名 drop 字段名;
  • 修改表名
rename table 旧的表名 to 新的表名;
  • 另一种修改表名写法
alter table 旧表名 rename 新表名;

二、DML

定义:指数据操作语言,用来对数据库中表的数据进行记录与更新

插入:insert

-- 插入全部字段
-- 写数据的时候,有多少列就有多少值
insert into 表名 values(列1的值,列2的值,……);
-- 只插入表中几列的值,其它列不写值
insert into 表名 (列名1,列名3)values(列1的值,列3的值);
insert into 表名 values
(列1的值,列2的值,……),
(列1的值,列2的值,……),
(列1的值,列2的值,……),
(列1的值,列2的值,……),
(列1的值,列2的值,……);

删除:delete

delete from 表名 where 条件; -- 带条件删除
delete from 表名 ; -- 删除整个表数据
truncate table 表名; -- 删除整个表数据
truncate  表名; -- 删除整个表数据

更新:update

update 表名 set 字段名=值,字段名=值,字段名=.....;-- 修改整个表名
update 表名 set 字段名=值,字段名=值,字段名=.....where 条件; -- 指定修改

三:约束

概念:实际上就是表中数据的限制条件

作用:表在设计的时候加入约束的目的,就是为了保证表中的记录完整性和有效性

约束分类:

主键约束(primary key) PK

概念:

  1. MySQL主键约束是一个列或多个列的组合,其值能唯一的标识表中的每一行,方便在RDBMS中尽快的找到某一个行。
  2. 主键约束相当于唯一约束+非空约束的组合,主键约束的列不允许重复,也不允许出现空值
  3. 每个表最多允许一个主键
  4. 主键约束的关键字:primary key
  5. 当创建主键的约束的时候,系统会默认在所在的列和列组合上建立对应的唯一索引

操作:

  1. 添加单列主键

    定义完字段之后指定主键:

    create table 表名(
        字段1 类型(长度) 约束,
        ...,
        constraint 约束名     primary key (字段名)
    );
    

    在定义字段的同时指定主键:

    create table 表名(
    字段1 类型(长度)  primary key
    );
    
  2. 添加多列的联合主键

    就是这个主键是由一张表中多个字段组成

    注意:当主键是由多个字段组成时,不能直接在字段名后面声明主键约束;

    一张表只能有一个主键,联合主键也是一个主键。

    create table 表名(
        ...
        primary key(字段1,字段2,字段3...)
    );
    
  3. 删除主键

    alter table 表名 drop primary key;
    
  4. 创建表完成之后,添加主键

    alter table 表名 add primary key(字段名);
    

自增长约束(auto_increment)

概念:

​ 在MySQL中,当主键定义为自增长后,这个主键的值就不需要用户输入数据了,而是由数据库系统根据定义自动赋值,每增加一条记录,主键就会自动以相同的步长进行增长,通过给字段添加auto_increment属性来实现主键自增长

create table 表名(
字段1 类型(长度) 约束 auto_increment
)auto_increment=100; -- 从100开始

特点:

  1. 默认情况下,auto_increment的初始值为1,每增加一条记录就字段值加一;

  2. 一个表中只能有一个字段使用auto_increment约束,且该字段必须有唯一索引,避免序号重复(主键或主键一部分)

  3. 自增长约束的字段必须具备not null 属性

  4. auto_increment约束的字段只能是整数类型(tinyint,int,BIGINT)等

  5. auto_increment约束字段的最大值是被该字段的数据类型约束,如果到达上限,auto_increment约束就会失效

指定自增字段的初始值

alter table 表名 auto_increment=初始值;

非空约束(not null)

概念:非空约束,指字段的值不能为空,对于使用了非空约束的字段,如果用户在添加数据时没有指定值,数据库系统就会报错

字段名 数据类型 not null;

alter table 表名 modify 字段 类型 not null;

唯一性约束(unique key)

概念:指所有记录中字段的值不能出现重复,例如id字段加上唯一性约束以后,每一条记录的id值都是唯一的,不能重复出现。

字段名 数据类型 unique ;

alter table 表名 add constraint 约束名 unique (指定列);


alter table 表名 drop index (约束名)字段名;-- 删除约束

默认约束(default)

概念:MySQL默认值约束用来指定某列的默认值

字段名 类型 default 默认值;

alter table 表名 modify 列名 类型 default 默认值; -- 可以修改,也可以添加

alter table 表名 modify column 字段名 类型 default null; -- 删除默认约束

外键约束(foreign key) FK

定义:外键约束是表的一个特殊字段,经常和主键约束一起使用,对于两个具有关联关系的表来说,相关字段中主所在表就是主表(父表),外键所在表就是从表(子表)

特点(定义一个外键时,需要遵守的规则):

  1. 主表必须已经存在于数据库中,或者是当前正在创建的表
  2. 必须为主表定义主键
  3. 主键不能包含空值,但是允许在外键中出现空值,也就是说,只要外键的每个非空值出现在指定的主键中,那么这个外键的内容就是正确的
  4. 在主表的表名后面指定列名或列名的组合,那么这个列或列的组合必须是主表的主键或候选键
  5. 外键中列的数目必须和主表的主键中的列的数目相同
  6. 外键中列的数据类型必须和主表的主键中的列的数据类型相同

方式一:在创建表的时候设置外键约束

语法:
constraint 外键名  foreign key 字段名 [,字段名2,...] references 主表名 主键列  [,主键列2,...]

例子:

create database mydb3; 
use mydb3;
-- 创建部门表
create table if not exists dept(
  deptno varchar(20) primary key ,  -- 部门号
  name varchar(20) -- 部门名字
);
create table if not exists emp(
  eid varchar(20) primary key , -- 员工编号
  ename varchar(20), -- 员工名字
  age int,  -- 员工年龄
  dept_id varchar(20),  -- 员工所属部门
  constraint emp_fk foreign key (dept_id) references dept (deptno)    -- 外键约束
);

方式二:在创建表之后设置外键约束

语法:alter table <数据表名> add constraint <外键名> foreign key(<列名>) references <主表名> (<列名>);

例子:
alter table emp add constraint emp_fk foreign key (dept_id) references dept (deptno);

删除外键约束:

语法:alter table <表名> drop foreign key <外键约束名>;

例子:alter table emp drop foreign key emp_fk;

四:DQL

基本查询,单表查询

简单语法:
select * from 表名 where 条件;

-- 1.查询所有的商品
SELECT * FROM product;
-- 2查询商品名称和价格
SELECT pname,price FROM product;
-- 3.表别名
SELECT * FROM product AS p WHERE p.pname="美的冰箱";
-- 4.列别名
SELECT pname 商品名,price 价格 FROM product
-- 5.去掉重复值
SELECT DISTINCT price FROM product
-- 查询结果是表达式;将使用商品的价格+10进行显示
SELECT pname,price+10 FROM product;
-- 查询商品名称为“海尔洗衣机”的商品所有信息:
SELECT * FROM product  WHERE pname="海尔洗衣机";
-- 查询价格为800商品
SELECT * FROM product  WHERE price=800;
-- 查询价格不是800的所有商品
SELECT * FROM product  WHERE NOT(price=800);
-- 查询商品价格大于60元的所有商品信息
SELECT * FROM product  WHERE price>60;
-- 查询商品价格在200到1000之间所有商品
SELECT * FROM product  WHERE price>=200 AND price<=1000;
SELECT * FROM product  WHERE price BETWEEN 200 AND 1000;
-- 查询商品价格是200或800的所有商品
SELECT * FROM product WHERE price = 200 OR price = 800;
SELECT * FROM product WHERE price IN(200,800);
-- 查询含有‘裤'字的所有商品
SELECT * FROM product WHERE pname LIKE '%裤%' ;
-- 查询以'海'开头的所有商品
SELECT * FROM product WHERE pname LIKE '海%';
-- 查询第二个字为'蔻'的所有商品
SELECT * FROM product WHERE pname LIKE '_蔻%';
-- 查询category_id为null的商品
SELECT * FROM product WHERE category_id IS NULL ;
-- 查询category_id不为null的商品
SELECT * FROM product WHERE category_id IS NOT NULL ;
-- 使用least求最小值
SELECT LEAST(10,20,NULL,40);
-- 使用greatest求最大值
SELECT GREATEST(10,20,40);



复杂语法:
select[all|distinct] 目标列的表达式 别名,目标列的表达式 别名,... from 表名或视图名 别名,表名或视图名 别名 
<where 条件表达式> 
<group by <别名>>  -- 分组查询
<having <条件表达式>> -- 分组之后的条件删选
select * from 表名 order by 列名 [asc|desc]; -- 排序
特点:
asc是升序(默认),desc是降序
order by 用于子句中可以支持单个字段,多个字段,表达式,函数,别名
order by 子句,放在查询语句的最后面,limit子句除外
<limit 数字或者列表> -- 分页

排序查询

select * from 表名 order by 列名 [asc|desc]; -- 排序

特点:
asc是升序(默认),desc是降序
order by 用于子句中可以支持单个字段,多个字段,表达式,函数,别名
order by 子句,放在查询语句的最后面,limit子句除外

聚合查询

聚合函数:

  • count( ) 统计指定列不为null的记录的行数
  • sum( ) 计算指定列的数值和,如果指定的列的类型不是数值类型,那么计算的结果是0
  • max( ) 计算指定列的最大值,如果指定的列的类型是字符串类型,那么就使用字符串排序运算
  • min( ) 计算指定列的最小值,如果指定的列的类型是字符串类型,那么就使用字符串排序运算
  • avg( ) 计算指定列的平均值,如果指定的列的类型不是数值类型,那么计算的结果是0

聚合函数–null值的处理:

  • count函数对null值的处理:如果count函数的参数为*,则统计所有记录的个数,如果参数为字段,则不统计含有null值的记录个数

  • sum和avg函数对null值的处理:这两个函数是没有null值的存在,就好像是该记录不存在

  • max和min函数对null值的处理:这两个函数是没有null值的存在,就好像是该记录不存在

分组查询 (group by) 分组后条件筛选(having)

  • 分组之后对统计结果进行筛选的话必须使用having不能使用where

  • where子句用来筛选from子句中指定的操作所产生的行

  • group by 子句用来分组where子句的输出

  • having子句是用来从分组的结果中进行筛选

select * from 表名 group by  分组的字段 having 分组条件;

分页查询:limit

-- 显示前n条
select * from 表名 limit 条数; 
-- 分页显示
select * from 表名 limit m,n;
-- m代表整数,表示第几条索引开始,计算方式=((当前页-1)*每页显示条数)
-- n表示查询多少数据,计算方式=(每页的条数*当前页数)

五、多表查询

多表操作:对两个或两个以上的表进行操作

多表之间的关系:MySQL中多表之间的关系可以概括为:一对一,一对多,多对一,多对多

一对一关系:

实现:在任意表中添加唯一外键,指向另一方主键,确保一对一关系(少见,遇见了就合并)

一对多/多对一关系:

例如:部门和员工

一个部门有多个员工,一个员工只能对应一个部门

实现:在多的一方建立外键,指向一的一方的主键

多对多关系

例如:学生和课程

实现:需要借助第三张中间表,中间表至少包含两个字段,将多对多的关系拆成一对多的关系,中间表至少有两个外键,分别指向原来两个表的主键

多表联合查询

介绍:多表查询就是同时查询两个或两个以上的表,因为有时候用户在查看数据的时候,需要显示的数据来自于多张表

多表查询的分类

1,交叉连接查询:select * from 表A,表B;

2,内连接查询:关键字(inner join)

隐式内连接:select * from 表a,表b where 条件;

显示内连接:select * from 表A inner join 表B on 条件;(在MySQL中,inner可以省略)

3,外连接查询:关键字(outer join)

  • 左外连接:left outer join
  • 右外连接:right outer join
  • 满外连接:full outer join

4,子连接查询:select的嵌套

5,表的自关联:将一张表当成多张表使用

查询种类特点关键字
全连接交叉连接(笛卡尔积),把两张表的数据进行交叉组合,A*B了解
内连接两表的交集部分inner join
外连接左外连接:取左表的全部数据+左右两表的交集
右外连接:取右表的全部数据+左右两表的交集
自然连接natural join
和内连接有些相似,它会自动去掉相同的字段
取两表的交集数据,并且去掉相同的列
了解natural join
自连接需要使用表别名,并且使用一个关键字段进行连接join 使用表别名
嵌套连接子查询
查询语句当中再嵌套查询语句
select中嵌套select

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

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

相关文章

Allegro174版本新功能介绍之去掉拷贝自动偏移功能

Allegro174版本新功能介绍之去掉拷贝自动偏移功能 Allegro升级到了174版本的时候,在用拷贝功能的时候,不管怎么拷贝都会出现偏差,即便是拷贝坐标的方式,如下图 那是因为174新增了一个自动粘贴的功能,按照下面的步骤可以去除自动粘贴的功能,具体操作如下 选择Setup选择Use…

1.《计算机组成原理》之初识计算机系统

一、基本内容&#xff1a;基本部件的结构和组织方式。基本运算的操作原理。基本部件和单元的设计思想。二、特色&#xff1a;计算机组成的一般原理&#xff0c;不以具体机型为依托。采用自顶向下的方式、层层细化。三、补充&#xff1a;一、基本内容&#xff1a;1.这门课讲什么…

【JavaScript】JavaScript中的时间函数

JavaScript中的时间函数 关于JavaScript里面时间的函数&#xff1a; 方法描述Date()返回当日的日期和时间。getDate()从Date对象返回一个月中的某一天&#xff08;1 ~ 31&#xff09;。getDay()从Date对象返回一周中的某一天&#xff08;0 ~ 6&#xff09;。getMonth()从Date…

LeetCode 热题HOT100-两数之和(C语言)

LeetCode 热题HOT100-两数之和&#xff08;C语言&#xff09; 作为一名程序语言的学习者&#xff0c;刷力扣我想是必要经历的一条路&#xff0c;所以我也在这里分享刷题后所得知识&#xff0c;也可以帮助更多人理解题意。 给定一个整数数组 nums 和一个整数目标值 target&#…

Zynq PS之UART调试

在创建应用工程时&#xff0c;选择Hello World模板即可&#xff0c;以XCZU21DR开发。 硬件原理图如下&#xff1a; Vivado中添加&配置IP 添加Zynq UltraScale MPSoc IP。 UART设置 DDR配置 硬件设计中选择的DDR4型号是MT40A2G8VA-062E IT&#xff0c;DDR配置如下图&…

6、SySeVR复现——Data preprocess(下)

紧接着上篇SySeVR复现——Data preprocess&#xff08;上&#xff09;5、SySeVR复现——Data preprocess&#xff08;上&#xff09;_sliver呀的博客-CSDN博客 目录 5、训练Word2vec模型 6、token向量化且划分数据集 7、固定每一个切片的长度 5、训练Word2vec模型 对应crea…

Jetpack Compose中使用Notification

发送通知相关的主要有两个关键的类 NotificationCompat.Builder 和 NotificationManagerCompat 为方便使用&#xff0c;首先定义一个扩展工具类来管理通知 const val MAIN_CHANNEL_ID "MainChannel ID" const val MAIN_CHANNEL "MainChannel"fun Contex…

人工智能导论实验——前馈神经网络

实验目的通过实验了解全连接神经网络的结构&#xff0c;应用全连接网络处理分类和回归任务。实验任务1&#xff09;初级实验&#xff1a;①手写体图像识别实验&#xff1b;②FashionMnist图像分类实验&#xff1b;③汽车里程数预测实验。2&#xff09;中级实验&#xff1a;①鸢…

数据集划分和交叉验证

机器学习实践中&#xff0c;为防止模型出现过拟合问题&#xff0c;需要预先将数据划分为训练集和测试集&#xff0c;训练集用来建模&#xff0c;训练模型&#xff0c;测试集用来提前测试模型的实际预测能力&#xff0c;这期间就会出现不同的数据集划分和模型评价方法&#xff0…

Linux常用命令——alias命令

Linux命令查询工具 alias 用来设置指令的别名 补充说明 alias命令用来设置指令的别名。我们可以使用该命令可以将一些较长的命令进行简化。使用alias时&#xff0c;用户必须使用单引号将原来的命令引起来&#xff0c;防止特殊字符导致错误。 alias命令的作用只局限于该次登入…

EventLoop与宏任务和微任务

1、JavaScript 是单线程的语言 JavaScript 是一门单线程执行的编程语言。也就是说&#xff0c;同一时间只能做一件事情。 单线程执行任务队列的问题&#xff1a;如果前一个任务非常耗时&#xff0c;则后续的任务就不得不一直等待&#xff0c;从而导致程序假死的问题。 2、同步…

性能优化系列之『混合式开发:Flutter内核及优势介绍』

文章の目录一、愿景二、技术优势三、底层实现四、选型建议写在最后一、愿景 A portable toolkit for building beautiful experiences wherever you might want to paint pixels on the screen.一个拥有美好构建体验的便携式的工具包&#xff0c;可以让你在屏幕的任何地方绘制…

LeetCode题解 二叉树(十四):669 修改二叉搜索树;108 将有序数组转换为二叉搜索树;538 把二叉搜索树转换为累加树

二叉树 669 修改二叉搜索树 medium 给你二叉搜索树的根节点 root &#xff0c;同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树&#xff0c;使得所有节点的值在[low, high]中。修剪树 不应该 改变保留在树中的元素的相对结构 (即&#xff0c;如果没有被移除&#xf…

数据可视化系列-06数据分析工具QuickBI

文章目录数据可视化系列-06数据分析工具QuickBI一文介绍QuickBIQuick BI 的基本对象快速入门Quick BI产品架构界面说明菜单栏我的看板工作台首页通过仪表板分析数据数据可视化系列-06数据分析工具QuickBI 参考&#xff1a; Quick BI 数据可视化分析平台 QuickBI官方文档 一文…

Jina AI 荣获「2022 稀土掘金引力榜」年度新锐企业 Top 10 称号!

2023 年 1 月 6 日&#xff0c;由稀土掘金技术社区打造的「掘金引力榜」正式公布。凭借在开源技术、产品等领域的积极布局&#xff0c;在社区生态影响力的突出贡献&#xff0c;Jina AI 荣获「掘金引力榜 2022 年度新锐企业 Top10」&#xff01;「掘金引力榜」是由稀土掘金技术社…

什么是商家转账到零钱

1. 什么是商家转账到零钱商家转账到零钱为商户提供向一个或者同时向多个用户微信零钱转账的能力&#xff0c;商户可免费使用。1.1. 使用场景商户可以使用商家转账用于现金营销、分销返佣、行政补贴、行政奖励、保险理赔、佣金报酬、企业报销、企业补贴、服务款项、采购货款等向…

阿里微服务质量保障系列(二):研发流程知多少

持续坚持原创输出&#xff0c;点击蓝字关注我吧介绍研发流程主要是给大家一个体感&#xff0c;可以直观感受阿里测试工程师从项目的立项到最终发布经历了哪些过程、做了什么工作。需求的产生刚毕业工作那会&#xff0c;认为需求来源于产品&#xff0c;把PD宣讲的产品需求奉为圭…

12.30第一周 星期五SSH

SSH功能&#xff1a;1.远程连接 2.sftp 1. 使用之前首先确认系统中有无 ssh 的软件包 rpm -qa | grep ssh 主程序或执行文件位置&#xff1a;/usr/sbin/ss服务端配置文件: /etc/ssh/sshd_config服务器用客户端的公钥对数据---->加密---->到客户端时&#xf…

TemplateFlow:一个跨物种,多尺度脑部模板和图谱的共享平台

Problem大脑的参考模板在神经影像工作流程中起着核心作用&#xff0c;是报告标准化结果的基础。而模板或者图谱的选择是不同研究中方法学差异的一个相关来源&#xff0c;最近被认为是对神经科学可重复性的一个重要挑战而受到关注。大多数情况下&#xff0c;我们所使用的模板由神…

Linux中Shell与环境变量与配置文件

Shell是什么 Shell是个程序&#xff0c;他会在用户登录系统后系统开启的&#xff0c;他可以通过标准输入来接收命令&#xff0c;然后执行命令&#xff0c;Shell可以执行内部命令和外部命令&#xff0c;内部命令就是Shell程序里面自己的逻辑&#xff0c;外部命令是Shell调用其他…