MySQL基本操作 DDL DML DQL三大操作介绍

    • `DDL` 数据(结构)定义 创建表
    • `DML` 数据操作 增删改
    • `DQL` 查询语句

DDL 数据(结构)定义 创建表

创建 删除数据

  • 注释 --空格+内容

  • 创建数据库

    • CREATE DATABASE [if not exists] 数据库名 [ CHARSET utf8]
    • eg:CREATE DATABASE IF NOT EXISTS school CHARSET utf8
    • 如果对应school不存在,则创建新的数据库 且编码使用utf8
  • 删除数据库

    • DROP DATABASE 数据库名 / [IF EXISTS数据库名]
    • DROP DATABASE IF EXISTS school
  • 修改字符集

    • ALTER DATABASE 数据库名 CHARSET 字符集名
  • 创建表

    • :是数据存储的最常见和最简单的形式,是构成关系型数据库的基本元素

    • 每一个表都有 表头表尾 表头定义表明和列名 表中的被看作是文件中的记录,表中的列被看作是这些记录的字段。

      • 设计
        • 表名
        • 表中的字段
        • 字段的数据类型和长度
        • 哪些约束
      • 确定表名
    • 数据类型

      • char(n) 长度为n的定长字符串,最大长度为255个字符

      • varchar(n) 最大长度为n的可变字符串

      • date 日期 包含年月日

      • datetime 年月日 十分秒

      • 整数

        • 类型字节最小值最大值
          TINYINT1-128-127
          SMALLINT2-32768-32767
          MEDIUMINT3-888608-888607
          INT4-2147483648-2147483647
          BIGINT8-9883372036854775808-9883372036854775807
        • signed 有符号 unsigned 无符号 默认是有符号

      • 浮点

    • 语法

    • 创建表 CREATE TABLE 表名(列名 数据类型 [约束] [默认值] [ 注释],......)

      • CREATE TABLE 表名(number INT,NAME VARCHAR(5),gender CHAR(1),birthday DATE,phone VARCHAR(11),height DECIMAL(3,2),reg_time DATETIME
        )-- CHAR(n) 定长的字符串  固定存储n个字符,长度不够n空格补齐
        -- VAECHAR(n) 可变长度的字符串 n为最大长度 如果只占了小于n的m个字符 实际占有m个空间位置	
        
    • 删除表**DROP TABLE [if exists ]表名**

    • 修改表**RENAME TABLE 旧表名 TO 新表名**

    • 复制表结构**CREATE TABLE 新表名 LIKE 被复制表名;**

      • CREATE TABLE student LIKE stu;//把student的结构复制给stu;
        
    • 主键:在一张表中代表唯一的一条记录,不能为空,不能重复

    • 约束

      • PRIMARY KEY 设置主键约束,添加主键约束后,值不能重复,一个表中只能有一个列是主键

      • 主键列可以唯一的表示某一行数据

      • mysql中主键可以设置为自动增长 AUTO_INCREMENT

      • NOT NULL不能为空约束

      • UNIQUE 唯一性约束 不能重复

      • 检查约束 设置条件

      • 注释 COMMENT + 注释

      • 用法

        CREATE TABLE student(number INT PRIMARY KEY AUTO_INCREMENT COMMENT '学号主键',NAME VARCHAR(6) NOT NULL,birthday DATE,phone VARCHAR(11) NOT NULL UNIQUE,heigth DECIMAL(3,2) CHECK(heigth<3),reg_time DATETIME
        )
        

执行某一个询问 必须选中

DML 数据操作 增删改

插入数据

  • 方式1: INSERT INTO 表名(列1,列2……,列n) VALUES(值1,值2…..,值n);
  • 方式2: INSERT INTO 表名 set 列名1=值1,..列名;
  • 方式3: INSERT INTO 表名(列1,列2……,列n) VALUES(值1,值2…..,值n),(值1,值2…..,值n);
  • 方式4: INSERT INTO 表名(列1,列2……,列n) 查询语句(查询的列数与插入列数匹配);

修改数据

  • UPDATE 表名 SET列名 = '新值' WHERE 条件

删除数据

  • DELETE FROM 表名 WHERE 条件
  • TRUNCATE TABLE 表名;//清空整张表

DQL 查询语句

  • 查询指定的列

    • **语法 : ** SELECT [查询列表] FROM 表名
    • 结果可以是:表格中的字段,常量,表达式,函数
    • 查询的结果是虚拟表格,不可以操作 是只读的
    • 可以对查询结果进行 算术运算(+ - * /);
    • **特点: **
      • 查询的列表可以是:表中的字段,常量,表达式,函数
      • 查询的结果是一个虚拟的表格
  • 查询结果处理

    • 特定列查询 select column 1, column2 form table(表名)

    • 全部列的查询select * from TABLE (表名)

      • -- 使用该表来进行举例子
        CREATE DATABASE IF NOT EXISTS student  CHARSET utf8CREATE TABLE stu(
        id INT PRIMARY KEY NOT NULL AUTO_INCREMENT, 
        number INT(5) NOT NULL, 
        stuname VARCHAR(10) NOT NULL, 
        age INT(3) CHECK(age>18), 
        birthday DATE, 
        weight DOUBLE, 
        opertime DATETIME
        )INSERT INTO stu (number ,stuname,birthday)VALUES(456,'cwy','2023-01-01');
        
      • image-20231220192616990

    • 算术运算符: + - * /

    • 排除重复行:select distinct column1,column2 from table

    • -- 查询指定的列  * 表示查询所有列
      SELECT id,number FROM stu
      SELECT * FROM stu
      -- 查询结果进行算术运算
      SELECT id+1, number/2 FROM stu
      -- 查询去重  对查询结果进行去重
      SELECT DISTINCT stuname FROM stu
      
    • image-20231220192647855

    • 查询的时候可以使用函数 select也是一个函数

      • 函数:类似于java中方法,将一组逻辑语句事先在数据库可以中定义好,可以直接调用
      • 分类:
        • 单行函数:如concat,length,ifull等;
        • 分组函数:做统计使用,又称为统计函数,聚合函数,组合函数
    • 单行函数

      • 字符函数

        • length()函数:获取参数值的字节个数

        • SELECT stuname,LENGTH(stuname) FROM stu
          
        • image-20231220192723831

        • char_length(列名)获取变量字符串的长度

        • SELECT stuname,LENGTH(stuname) FROM stu
          -- 与length()用法一样
          
        • concat(str1,str2,.....)拼接字符串 str 指的是为字符串的列 如果其中str含NULL结果都为NULL

        • instr(str ,指定字符)查找指定字符在str中首次出现的位置

        • ELECT INSTR(stuname,'w')  FROM stu
          
        • image-20231220193449507

        • trim(str) 默认去除str前后的空格,str为指定的子串且来自父类字符串

        • lpad(str,length,字符),与 rpad(str,length,字符) 在字符左右填充length长的字符 注意length指的是字节的长度

        • -- lpad(str,length,字符)  在str左边填充length长度的 字符
          SELECT LPAD(stuname,6,'w')  FROM stu
          -- rpad 同上 在右边填充
          
        • image-20231220194228464

        • replace(sre, 目标字符,替换字符)

        • -- replace(str,目标字符,替换字符) 把str中的目标字符  替换为 替换字符
          SELECT REPLACE(stuname,'d','w')  FROM stu
          

        • upper(str)转大写 lower(str)转小写 str可以是字符串的列也可也是 字符串 但如果是字符串他会单独显示一列为str大写

        • -- upper()转大写  lower() 转小写 
          SELECT UPPER(stuname) FROM stu -- 为字符串的列
          
        • image-20231220194728980

        -- upper()转大写  lower() 转小写
        SELECT UPPER('dqw') FROM stu
        
        • image-20231220194820834
      • 逻辑处理

        • case when 条件 then 结果1 else 结果2 end;(可以有多个when)

        • -- 表示id为123时 为1 否则都为2
          SELECT CASE WHEN   id=123 THEN 1 ELSE 2 END FROM stu;
          
        • image-20231220195308612

          • is null SELECT CASE WHEN age IS NULL THEN 1 ELSE 2 END FROM stu; 判断age是否为null
        • ifnull(被检测值,默认值)函数检测是否为null如果为null返回指定值,否则返回原本值

        • SELECT IFNULL(age,0) FROM stu;-- 判断age是否为空 不是返回原本值 否则返回 0
          
        • image-20231220195729364

        • if(条件,结果1,结果2) if- else 的效果

        • SELECT IF(age>50,0,1) FROM stu;
          
        • image-20231220200123703

      • 日期函数

        • now();返回当前日期

        • -- 获取当前日期 年月日 时分秒
          SELECT NOW() FROM stu;
          

          image-20231220200539675

        • curdate()获取当前日期 不包含时分秒 curtime() 获取当前时分秒 不包含日期

        • 可以获取指定部分 年 ,月, 日, 小时 , 分钟,秒

        • TEAR(日期列) MONTH(日期列) DAY(日期列) HOUR(日期列) MINUTE(日期列) SECOND(日期列)

        • str_to_date(字符串格式的日期,格式)将日期格式的字符转化为指定格式的日期

        • date_format(日期列,格式) 将日期转化为字符串

        • datediff(big ,small)返回两个日期相差的天数

        • 日期格式

          • image-20231220201533179
      • 分组函数

        • 功能: 用作统计使用,又称为聚合函数或统计函数或组函数

        • 分类:sum求和 avg平均值 max最大值 min最小值 count计数(非空)

          1. sum,avg一般用于处理数值型max min count可以处理任何类型
          2. 以上分组函数都可以忽略null值
          3. count函数的一般使用 count(*)用作统计行数.
          4. 和分组函数一同查询的字段要求是 group by后的字段 group by必须在语句最后
        • - 求和函数
          SELECT SUM(id) FROM stu;
          -- 求平均
          SELECT AVG(id) FROM stu;
          -- sum avg 只可以统计 数值类型  -- 求最大值
          SELECT MAX(weight) FROM stu
          -- 求最小值
          SELECT MIN(weight) FROM stu
          -- 统计函数
          SELECT COUNT(weight>3) FROM stu;
          -- 分组函数
          -- group by 分组函数 后面对应的变量 要与前面出现的变量一样()
          SELECT YEAR(birthday), COUNT(YEAR(birthday)) FROM stu GROUP BY YEAR(birthday);
          
        • image-20231220202316749

        • 分组函数

        • image-20231220202400081

        • image-20231220203957326

      • 条件查询

        • where(条件) where子句紧跟from子句

          • 语法select <结果> from<表名>where<条件>

          • SELECT stuname FROM stu WHERE stuname LIKE '%w%';
            -- 模糊匹配  stuname 含w数据
            
        • image-20231220202746174

        • 条件中的比较

          • = ,!= 或<>,>,<,>=,<=
          • 逻辑运算
            • and
            • or
            • not
        • 条件查询中模糊查询

          • LIKE: 是否匹配于一个模式,一般和通配符搭配使用,可以判断字符型数值或数值型

          • 通配符: % 任意多个字符

            • 条件查询 'w%'表示以w开头的模糊匹配 '%w’表示以w结尾的模糊匹配 '%w%'表示包含w的模糊匹配
          • SELECT stuname FROM stu WHERE stuname LIKE '%w%';
            -- 模糊匹配  stuname 含w数据
            -- 结果如上
            
          • between and 两者之间,包含临界值

          • In 判断某字段的值是否输入in列表中的某一项

          • IS NULL(为空的) 或 IS NOT NULL(不为空的)

      • 联合语句 UNION UNION ALL

        • UNION

          [SQL 语句 1]

          UNION

          [SQL 语句 2]

        • UNION ALL

          [SQL 语句 1]

          UNION ALL

          [SQL 语句 2]

        • 注:当使用union时 MySQL会把结果集中重复的记录删除掉,而是用UNION ALL ,MySQL会把所有记录返回,其效率高于union

      • 排序

        • 如果想对查询的结果进行排序 使用ORDER BY 子句排序

          • ORDER BY [ASC/DESC]

          • asc 代表的是升序 ,desc代表的是降序,如果不写,默认为升序

          • ORDER BY可以支持单个字段与多个字段

          • -- 排序 order by asc 是升序 desc是降序 
            SELECT stuname ,weight FROM stu ORDER BY weight ASC
            
          • image-20231220205122063

        • 数量限制

          • limit子句:对查询显示结果限制数目(sql语句最末尾位置)
          • SELECT * FROM table LIMIT offset rows
          • SELECT * FROM table LIMIT 0,5
        • 分组查询

        • 语法:

          • SELECT [分组函数] ,[列](要求出现在group by的后面)

            from [表]

            [where 筛选条件]

            group by 分组的列表 //分组

            [having 分组后筛选] //

            [order by 子句] //排序

          • 注意:查询列表比较特特殊,要求是分组函数和group by后出现的字段

          • 数据源源位置关键字
            分组前的筛选原始表group by子句前面where
            分组后筛选分组后的激活集group by 的后面having

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数字门牌管理系统:提升数据质量与服务品质的关键

一、引言 在当今社会&#xff0c;各行各业对数据质量的要求越来越高。为了满足客户需求并遵循国家行业标准&#xff0c;数字门牌管理系统应运而生。该系统以建立项目建设标准规范为核心&#xff0c;旨在提升数据质量与服务品质。 二、建立标准规范&#xff0c;确保数据质量 …

ansible-playbook的Temlates模块 tags模块 Roles模块

Temlates模块 jinja模板架构&#xff0c;通过模板可以实现向模板文件传参(python转义)把占位符参数传到配置文件中去,生产一个目标文本文件&#xff0c;传递变量到需要的配置文件当中 &#xff08;web开发&#xff09; nginx.conf.j2 早文件当中配置的是占位符&#xff08;声明…

GBASE南大通用数据库在Windows和Linux中创建数据源

Windows 中数据源信息可能存在于两个地方&#xff1a;在 Windows 注册表中&#xff08;对 Windows 系统&#xff09;&#xff0c; 或在一个 DSN 文件中&#xff08;对任何系统&#xff09;。 如果信息在 Windows 注册表中&#xff0c;它叫做“机器数据源”。它可能是一个“用 …

机器学习——分类评价指标

【说明】文章内容来自《机器学习——基于sklearn》&#xff0c;用于学习记录。若有争议联系删除。 1、评价指标 对于模型的评价往往会使用损失函数和评价指标&#xff0c;两者的本质是一致的。一般情况下&#xff0c;损失函数应用于训练过程&#xff0c;而评价指标应用于测试过…

整数比较(比较4个数并从小到大输出)C语言xdoj94

描述&#xff1a; 从键盘输入四个整数&#xff0c;要求按由小到大的顺序输出。 输入说明&#xff1a; 输入四个整数&#xff0c;以空格间隔。 输出说明&#xff1a; 输出排序后的整数&#xff0c;以空格间隔。 输入样例 样例1输入 -99 9 99 -9 输出样例 样例1输出 -99 -9 9 99 …

逆波兰计算器的完整代码

前置知识&#xff1a; 将中缀表达式转为List方法&#xff1a; //将一个中缀表达式转成中缀表达式的List//即&#xff1a;(3042)*5-6 》[(, 30, , 42, ), *, 5, -, 6]public static List<String> toIndixExpressionList(String s) {//定义一个List&#xff0c;存放中缀表达…

svn合并跟踪信息丢失

最近合并完了发现没有可以提交的合并信息&#xff0c;类似这样的&#xff1a; 红色部分框起来的灰色字体的&#xff0c;也就是合并信息 没有合并跟踪信息的话&#xff0c;下次合并时&#xff0c;就不知道上次合并了哪些内容&#xff0c;可能会重复合并&#xff0c;也可能漏合并…

Java反序列化链子分析-3

文章目录 前言Hessian反序列化TemplatesImplSpring AOPPartiallyComparableAdvisorHolderResin 前言 续接之前那篇Java反序列化-2的文章。 Hessian反序列化 Hessian是一种用于远程调用的二进制协议。它被广泛用于构建分布式系统中的跨平台通信&#xff0c;特别适用于Java语言…

【JS】事件循环机制

一、JS单线程、异步、同步概念 众所周知&#xff0c;JS是单线程&#xff08;如果一个线程删DOM&#xff0c;一个线程增DOM&#xff0c;浏览器傻逼了&#xff5e;所以只能单着了&#xff09;&#xff0c;虽然有webworker酱紫的多线程出现&#xff0c;但也是在主线程的控制下。we…

京东tp26旋转验证

记录一下&#xff0c;狗东的tp26旋转验证码&#xff0c;难点还是在这个轨迹上。我真的是一点都不喜欢玩轨迹&#xff01;&#xff01;&#xff01;&#xff01; 类似于百度旋转的图&#xff0c;不过他这个东西还是稍微有点差距的。 鉴于生病了脑子不太好使&#xff0c;就不过多…

KBU808-ASEMI适配高端电源KBU808

编辑&#xff1a;ll KBU808-ASEMI适配高端电源KBU808 型号&#xff1a;KBU808 品牌&#xff1a;ASEMI 封装&#xff1a;KBU-4 最大平均正向电流&#xff1a;8A 最大重复峰值反向电压&#xff1a;800V 产品引线数量&#xff1a;4 产品内部芯片个数&#xff1a;4 产品内…

Docker概述及介绍

Docker是近年来新兴的虚拟化工具&#xff0c;它可以和虚拟机一样实现资源和系统环境的隔离。 库&#xff0c;然后再安装应用&#xff1b; Container(Docker容器)&#xff0c;在宿主机器、宿主机器操作系统上创建Docker引擎&#xff0c;在引擎的基础上再安装应用。 Docker三…