【从删库到跑路】MySQL系列——详细讲解SQL的DDL,DML,DQL,DCL语句

🎊专栏【MySQL】
🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。
🎆音乐分享【如愿】
大一同学小吉,欢迎并且感谢大家指出我的问题🥰

文章目录

  • 🍔关系型数据库
    • ⭐概念
    • ⭐特点
  • 🍔MySQL数据库的数据类型
  • 🍔SQL通用语法
  • 🍔SQL分类
    • ⭐DDL语句操作——数据库
      • 🎈查询当前数据库
      • 🎈查询所有数据库
      • 🎈创建数据库
        • 🎈创建数据库并设置字符集
      • 🎈删除数据库
      • 🎈使用数据库
    • ⭐DDL语句操作——表
      • 🎈查询当前数据库的所有表
    • ⭐创建表
      • 🎈查询表结构
      • 🎈查询指定表的建表语句
    • ⭐DDL表操作——修改表
      • 🎈修改数据类型
      • 🎈修改字段名和字段类型
      • 🎈修改表名
      • 🎈删除字段
      • 🎈删除表
      • 🎈删除表,并且自动创建该表
    • ⭐总结
    • ⭐DML语句——添加数据
      • 🎈给 指定 字段添加数据
      • 🎈给 全部 字段添加数据
      • 🎈批量添加数据
        • 🏀注意
    • ⭐DML语句——修改数据
        • 🏀注意
    • ⭐DML语句——删除数据
        • 🏀注意
    • ⭐总结
    • ⭐DQL语句——查询数据
      • 🎈基本查询
        • 🏀查询多个字段
        • 🏀设置别名
        • 🏀去除重复记录
      • 🎈条件查询
      • 🎈聚合函数
        • 🏀注意
      • 🎈分组查询
        • 🏀where和having的区别
        • 🏀注意
      • 🎈排序查询
        • 🏀注意
      • 🎈分页查询
        • 🏀注意
    • ⭐DQL语句——执行顺序
    • ⭐总结
    • ⭐DCL语句—用户管理
      • 🎈查询用户
      • 🎈创建用户
      • 🎈修改用户密码
      • 🎈删除用户
        • 🏀注意
    • ⭐DCL语句—权限控制
      • 🎈查询权限
      • 🎈授予权限
      • 🎈撤销权限
    • ⭐总结

内容有点多,建议大家先看目录。

在这里插入图片描述

🍔关系型数据库

⭐概念

建立在关系模型基础上,由多张相互连接的二维表组成的数据库

⭐特点

🏀使用表存储数据,格式统一,便于维护
🏀使用SQL语言操作,标准统一,使用方便
在这里插入图片描述

🍔MySQL数据库的数据类型

通过客户端,连接MySQL数据库管理系统(DBMS),然后通过SQL语句,通过数据库管理系统创建数据库
也可以通过SQL语句,通过数据库管理系统,在指定的数据库中创建表
在一个数据库服务器中是可以创建多个数据库的,而在一个数据库中,又可以创建多张表,在表中,我们又能存储一条一条的结构
🏀所以数据库和表就是MySQL数据库的数据类型

(https://img-blog.csdnimg.cn/ddf395047a81437d80f59b01613b4307.png)**

🍔SQL通用语法

🏀SQL语句可以单行或多行书写,并且以分号结尾
🏀SQL语句可以使用空格或缩进来增强语句的可读性
🏀MySQL数据库的SQL语句不区分大小写,关键字建议大写
🏀单行注释:–注释内容(或#注释内容)
🏀多行注释:/ * 注释内容 * /

🍔SQL分类

在这里插入图片描述

⭐DDL语句操作——数据库

🎈查询当前数据库

select database();

在这里插入图片描述

🎈查询所有数据库

show databases;

在这里插入图片描述

🎈创建数据库

create database itcast;

可以加一个判断条件,如果不存在数据库的话,就创建一个,否则不创建

create database if not exists itcast;

在这里插入图片描述

🎈创建数据库并设置字符集

create database 数据库名称 default charset 字符集;

在这里插入图片描述

🎈删除数据库

drop database 数据库名称;

可以加一个判断条件,如果存在这个数据库,就删除,否则不删除
;

drop database if exists 数据库名称

在这里插入图片描述

🎈使用数据库

例如

use itcast;

表示我要切换到itcast数据库

在这里插入图片描述

⭐DDL语句操作——表

🎈查询当前数据库的所有表

show tables;

在这里插入图片描述

⭐创建表

在这里插入图片描述

SQL写完后要加上分号,如果没有分号,那么就可以写多行

在这里插入图片描述
数据库里面的字符串类型是varchar()(()里面是字符串长度)不是string

🎈查询表结构

desc 表名;

在这里插入图片描述

🎈查询指定表的建表语句

show create table 表名;

在这里插入图片描述

⭐DDL表操作——修改表

🎈修改数据类型

alter table 表名 modify 字段名 新数据类型(长度);

🎈修改字段名和字段类型

alter table 表名 change 旧字段名 新字段名 类型(长度) [comment 注释];

在这里插入图片描述

🎈修改表名

alter table 表名 rename to 新表名;

在这里插入图片描述

🎈删除字段

alter table 表名 drop 字段名;

在这里插入图片描述

🎈删除表

drop table 表名;

可以添加一个判断条件

drop table if exists 表名;

🎈删除表,并且自动创建该表

truncate table 表名;

为什么要这样子操作
虽然会重新创建该表,但是该表的所有数据都不存在了

⭐总结

在这里插入图片描述

⭐DML语句——添加数据

🎈给 指定 字段添加数据

insert into 表名(字段名1,字段名2, ……) value(值1,值2);

🎈给 全部 字段添加数据

insert into 表名 value (值1,值2);

🎈批量添加数据

insert into 表名(字段名1,字段名2,……) value(值1,值2……)(值1,值2……)(值1,值2……);

或者

insert into 表名 value(值1,值2……)(值1,值2……)(值1,值2……);

🏀注意

在这里插入图片描述

⭐DML语句——修改数据

update 表名 set 字段名1=值1,字段名2=值2,……[where 条件];

加上where,就是修改符合条件的数据,否则修改的是所有数据
在这里插入图片描述

🏀注意

修改语句的条件(where)可以有,也可以没有,如果没有条件,那么会修改整张表的所有数据

⭐DML语句——删除数据

delete form 表名 [where 条件]

加上where,就是修改符合条件的数据,否则修改的是所有数据

在这里插入图片描述

🏀注意

修改语句的条件(where)可以有,也可以没有,如果没有条件,那么会修改整张表的所有数据
🏳️‍🌈delete语句不能删除某一个字段的值(但是可以用update删除)

⭐总结

在这里插入图片描述

⭐DQL语句——查询数据

在这里插入图片描述

🎈基本查询

🏀查询多个字段

select 字段1,字段2,字段3……form 表名;
select * from 表名;

在这里插入图片描述
在这里插入图片描述

🏀设置别名

select 字段1 [AS 别名1],[AS 别名2]……from 表名;

在这里插入图片描述

🏀去除重复记录

select distinct 字段列表 form 表名;

在这里插入图片描述

🎈条件查询

select 字段列表 from 表名 where 条件列表;

条件
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

🎈聚合函数

概念:就是将一列数据作为一个整体,进行纵向计算
在这里插入图片描述

select 聚合函数(字段列表) from 表名;

🏀注意

null是不参与所有聚合函数的计算的

在这里插入图片描述

🎈分组查询

select 字段列表 from 表名 [where 条件] group by 分组字段名 [having 分组后过滤条件];

🏀where和having的区别

执行时机不同:where是分组之前进行过滤,不满足where条件,不参与分组,而having是分组之后对结果进行过滤
判断条件不同:where不能对聚合函数进行判断,而having可以

在这里插入图片描述

🏀注意

执行顺序:where>聚合函数>having
分组之后,查询的字段一般是聚合函数和分组字段,查询其他字段没有意义

🎈排序查询

在这里插入图片描述

select 字段列表 from 表名 order by 字段1 排序方式1,字段2 排序方式2;

在这里插入图片描述

🏳️‍🌈排序方式
asc 升序(默认)
desc 降序

🏀注意

如果是多字段排序,当第一个字段值相同时,才会根据第二个字段排序

🎈分页查询

select 字段列表 from 表名 limit 起始索引,查询记录数;

在这里插入图片描述

🏀注意

在这里插入图片描述

⭐DQL语句——执行顺序

在这里插入图片描述

⭐总结

在这里插入图片描述

⭐DCL语句—用户管理

DCL可以用来管理数据库成员,控制数据库的访问权限

在这里插入图片描述

🎈查询用户

use mysql;
select * from user;

可以直接查看用户表
在这里插入图片描述

🎈创建用户

create user '用户名'@'主机名' identified by '密码';

在这里插入图片描述

🎈修改用户密码

alter user '用户名'@'主机名' identified with mysql_native_password by '新密码';

在这里插入图片描述

🎈删除用户

drop user '用户名'@'主机名';

在这里插入图片描述

🏀注意

主机名可以用%通配,使用%后,表明可以用任意主机进行访问

⭐DCL语句—权限控制

我们创建了用户后,我们会发现,用户可以登录上MySQL,但是不能访问任何的数据库,只能访问一个系统库
原因就是用户创建好了之后,并没有给用户分配权限

在这里插入图片描述

🎈查询权限

show grants for '用户名'@'主机名';

🎈授予权限

grant 权限列表 on 数据库名.表名 to '用户名'@'主机名';

🎈撤销权限

remove 权限列表 on 数据库名.表名 from '用户名'@'主机名';

⭐总结

在这里插入图片描述

🥰如果大家有不明白的地方,或者文章有问题,欢迎大家在评论区讨论,指正🥰

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

开发工具-网络测试工具 POSTMAN 的脚本使用

开发工具-网络测试工具 POSTMAN 的脚本使用 postman 脚本应用基础设置变量、获取变量示例环境变量的使用测试 发送请求示例常用的变量、方法responseBody 获取响应体内容pm.response 获取响应信息pm.expect() JSON检查cheerio.load() 类似于 jquery 操作 html 元素 POSTMAN 是网…

RabbitMQ入门指南

人生永没有终点。只有等到你瞑目的那一刻,才能说你走完了人生路,在此之前,新的第一次始终有,新的挑战依然在,新的感悟不断涌现。 文章目录 一、MQ与RabbitMQ概述1. MQ简述2. MQ的优势3. MQ的劣势4. 常见的MQ产品5. Rab…

MySQL 数据库

文章目录 数据库的基本概念数据表数据库数据库管理系统数据库系统 数据库的发展史当今主流数据库介绍SQL Server (微软公司产品)Oracle (甲骨文公司产品)DB2 (IBM公司产品)MySQL (甲骨文公司收购…

Spring Boot日志文件

目录 前言🍭 一、日志的作用🍭 1、日志真实使用案例:🍉 二、日志怎么用🍭 1、自定义日志打印🍉 Ⅰ、在程序中得到日志对象🍓 常见的日志框架说明(了解)&#x1f35…

保姆级AT32F437 配置RT-Thread 以太网(UDP/TCP Server)

好记性不如烂笔头,既然不够聪明,就乖乖的做笔记,温故而知新。 本文档用于本人对知识点的梳理和记录。 一、前言 ENV版本:v1.3.5 rt-thread版本:V5 开发板:雅特力AT32F437 AT-START-F437 二、ENV配置 E…

java--类变量与实例变量--实验设计--村庄种树

目录 设计要求 设计流程图 程序代码 类Village代码 类MainClass代码 可以直接运行的代码 运行结果 类变量与实例变量的区别和类方法与实例方法的区别 idea的详细使用方法 设计要求 编写程序模拟两个村庄共同拥有一片森林;编写一个Village类,该类…

python爬虫:爬取网站所有页面上某些内容

举例场景:爬取腾讯课堂中,查询python的所有课程的封面图、课程标题、课程数量、课程价格,这4个部分的内容。 代码如下: import requests # import lxml # 导入用于请求的包lxml from bs4 import BeautifulSoup # 导入用于请求…

Tomcat 8.5 环境搭建指南

文章目录 导言环境搭建总结 导言 欢迎阅读本篇博客,本文将为您提供关于如何搭建Tomcat 8.5环境的详细指南。Tomcat是一个流行的开源Java Servlet容器,它提供了一个运行Java Web应用程序的平台。无论您是新手还是有经验的开发人员,本文都将帮…

4、架构:Canvas VS DOM

在可视化搭建的低代码平台中,设计器是一个非常关键的模块,可以帮助用户通过拖拽、配置等方式快速搭建应用界面。 在技术选型方面,目前市面上主流的设计器技术包括基于 HTML/CSS/JavaScript 的 Web 设计器。 在渲染方案方面,主流…

王道《计算机网络》思维导图汇总

第一章 1.1.1 概念与功能 1.1.2 组成与分类 1.1.3 标准化工作及相关组织 1.1.4 性能指标 速率 带宽 吞吐量 时延 时延带宽积 往返时延RTT 利用率 1.2.1 分层结构、协议、接口、服务 1.2.2 OSI参考模型 应用层 表示层 会话层 传输层 网络层 数据链路层 物理层 1.2.4 TCP/IP 参…

Linux下的分布式迁移工具dsync使用

一、Linux下的分布式迁移工具dsync使用 dsync 是一个在 Linux 系统上用于迁移文件和目录的工具。它可以在不同的存储设备之间进行数据同步和迁移操作。dsync 是 rsync 工具的一个衍生版本,专注于在本地文件系统之间进行数据迁移。 这里是官网:dsync 1、…

游泳买耳机买什么的比较好,列举几款实战性好的游泳耳机

对于运动用户来说,在运动时都会选择听一些节奏感比较强的音乐,让自己运动是更有活力。现在已经是三伏天中的前伏期间,不少人会选择在三伏天的日子里进行减肥瘦身,耳游泳已经成为很多人都首选运动,游泳是非常好的有氧运…

吐血整理!可免费使用的国产良心软件分享,几乎满足你办公需求

在这个信息化时代,软件已经成为我们办公和生活的必备工具。然而,市面上的大部分国产软件都需要付费才能使用,给我们的经济负担增加了不少。幸运的是,国内有一些良心软件,它们质量上乘,功能强大,…

2023牛客网秋招国内大厂最牛的 Java 面试八股文合集(全彩版)

秋收即将来临,找工作的小伙伴比比皆是,很对小伙伴早早的就开始储备技术,准备秋招面试了。 为了帮助小伙伴更好的应对面试,我拉来十几个大佬,汇总一线大厂的情况,给你整了一套超全的面试资料: 16…

深度学习项目实战二: LetNet5网络结构搭建

深度学习项目实战二: LetNet5网络结构搭建 文章目录 深度学习项目实战二: LetNet5网络结构搭建@[TOC](文章目录)一、卷积基本运算公式二、LetNet5网络1. 网络结构![在这里插入图片描述](https://img-blog.csdnimg.cn/0008fe6e5886414eac09eed49556ad99.png)2. 导入相关包3. 代码…

熔断与降级 Hystrix

一、Hystrix(豪猪)简介 1、Hystrix的设计目的 (1)对依赖服务调用时出现的调用延迟和调用失败进行控制和容错保护。 (2)阻止某一个依赖服务的故障在整个系统中蔓延,服务A->服务B->服务C,服务C故障了…

四、交换网络实验4——单臂路由配置

更多网络基础内容可见: 网络基础学习目录及各章节指引 4.6.4 配置单臂路由器 实验目的 学习配置单臂路由 实验工具 Cisco Packet Tracer 实验环境 安装模拟器的Windows系统 实验步骤 第一步:根据拓扑配置基本信息

【Linux修炼】开发工具使用

🌇个人主页:平凡的小苏 📚学习格言:命运给你一个低的起点,是想看你精彩的翻盘,而不是让你自甘堕落,脚下的路虽然难走,但我还能走,比起向阳而生,我更想尝试逆风…

无人机遥感在农林信息提取中的实现方法与GIS融合制图教程

详情点击链接:无人机遥感在农林信息提取中的实现方法与GIS融合制图 遥感技术作为一种空间大数据手段,能够从多时、多维、多地等角度,获取大量的农情数据。数据具有面状、实时、非接触、无伤检测等显著优势,是智慧农业必须采用的重…

Vue指令案例

案例需求&#xff1a; 将Vue数据模型中的数据以表格的形式渲染展示 具体代码如下&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-wid…