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

news2024/9/22 21:32:42

    • `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 utf8
        
        CREATE 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.coloradmin.cn/o/1325203.html

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

相关文章

【GitHub精选项目】IP 地址转地理位置:ip2region 完全指南

前言 本文为大家带来的是 lionsoul2014 开发的 ip2region 项目&#xff0c;一种高效的离线 IP 地址定位库。ip2region 提供了10微秒级别的查询效率&#xff0c;支持多种主流编程语言&#xff0c;是一种理想的 IP 定位解决方案。 这个开源项目可以实现 IP 地址到地理位置的精确映…

2017年第六届数学建模国际赛小美赛A题飓风与全球变暖解题全过程文档及程序

2017年第六届数学建模国际赛小美赛 A题 飓风与全球变暖 原题再现&#xff1a; 飓风&#xff08;也包括在西北太平洋被称为“台风”的风暴以及在印度洋和西南太平洋被称为“严重热带气旋”&#xff09;具有极大的破坏性&#xff0c;往往造成数百人甚至数千人死亡。   许多气…

SVN搭建指导

环境 centos 7.9 SVN安装方式一&#xff1a;yum 1.1 http服务 至今还没有搞定网页版&#xff0c;网页版需要搭建apache http服务。遇到如下问题&#xff1a; centos - svn: Could not open the requested SVN filesystem - Stack Overflow 在试了加777权限&#xff0c;加a…

校园圈子交友系统,APP小程序H5,三端源码交付,支持二开!实名认证,大V认证,地图找伴,二手平台!

校园圈子交友系统&#xff0c;是属于自主定义开发的系统&#xff0c;内容有很多&#xff0c;先截取一些给大家看看&#xff0c;让大家更多的了解本系统&#xff0c;然后再做评价&#xff01; 校园后端下载地址&#xff1a;校园圈子系统小程序&#xff0c;校园拼车&#xff0c;校…

Pycharm 关闭控制台多余窗口详解(console)

文章目录 1 问题描述2 解决办法2.1 步骤1&#xff1a;编辑配置2.2 步骤2&#xff1a;使用 Python 控制台运行&#xff08;取消勾选&#xff09;2.3 验证&#xff1a;再次运行&#xff0c;多余窗口消失 1 问题描述 2 解决办法 2.1 步骤1&#xff1a;编辑配置 菜单路径&#xf…

【bug日记】如何切换jdk版本,如何解决java和javac版本不一致

背景 今天在安装jenkins后&#xff0c;使用java运行war包的时候&#xff0c;提示jdk1.8版本太低&#xff0c;需要提高版本&#xff0c;所以就需要切换jdk版本 解决 在用户变量中&#xff0c;首先更改了JAVA_HOME的地址为17的目录&#xff0c;发现javac的版本改为17了&#x…

云原生扫盲篇

What 云原生加速了应用系统与基础设施资源之间的解耦,向下封装资源以便将复杂性下沉到基础设施层;向上支撑应用,让开发者更关注业务价值 云原生是一种构建和运行应用程序的方法,也是一套技术体系和方法论. Cloud 表示应用程序位于云中而不是传统的数据中心Native表示应用程序从…

函数帧栈的创建和销毁(一)

目录 什么是函数栈帧 理解函数栈帧能解决什么问题 函数栈帧的创建和销毁 什么是栈 认识相关寄存器和汇编指令 相关寄存器 相关汇编命令 esp和ebp 解析函数栈帧的创建和销毁 学前补充 函数的调用堆栈 什么是函数栈帧 我们在写C 语言代码的时候&#xff0c;经常会把…

ThinkPad E550c

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 例如&#xff1a;…

java8实战 lambda表达式、函数式接口、方法引用双冒号(中)

前言 书接上文&#xff0c;上一篇博客讲到了lambda表达式的应用场景&#xff0c;本篇接着将java8实战第三章的总结。建议读者先看第一篇博客 其他函数式接口例子 上一篇有讲到Java API也有其他的函数式接口&#xff0c;书里也举了2个例子&#xff0c;一个是java.util.functi…

2-高可用-负载均衡、反向代理

负载均衡、反向代理 upstream server即上游服务器&#xff0c;指Nginx负载均衡到的处理业务的服务器&#xff0c;也可以称之为real server,即真实处理业务的服务器。 对于负载均衡我们要关心的几个方面如下&#xff1a; 上游服务器配置&#xff1a;使用upstream server配置上…

mysql 23day DDL常用约束,数据类型

目录 数据库的四种语言常用约束&#xff08;DDL&#xff09;创建格式PRIMARY KEY&#xff1a;主键约束FOREIGN KEY&#xff1a;外键约束主键外键 联合测试开始测试 NOT NULL&#xff1a;非空约束UNIQUE&#xff1a;唯一约束DEFAULT&#xff1a;默认值约束zerofill 零填充auto_i…

vcomp140.dll丢失怎么办,vcomp140.dll丢失解决方法详解

在我多年的电脑使用经历中&#xff0c;我曾经遇到过一个非常棘手的问题&#xff0c;那就是vcomp140.dll丢失。这个问题让我苦恼了很久&#xff0c;但最终我还是找到了解决方法。今天&#xff0c;我想和大家分享一下我的经历&#xff0c;以及vcomp140.dll是什么&#xff0c;它丢…

AI创作系统ChatGPT商业运营网站系统源码,支持AI绘画,GPT语音对话+DALL-E3文生图

一、前言 SparkAi创作系统是基于ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统&#xff0c;支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美&#xff0c;可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作Ch…

用全志R128复刻自平衡赛车机器人,还实现了三种不同的操控方式

经常翻车的朋友们都知道&#xff0c;能在翻车后快速摆正车身的车才是好车。 就像动画《四驱兄弟》中展现的那样&#xff0c;在比赛中需要跟着赛车一起跑圈&#xff0c;而且赛车如果被撞翻还需要重新用手扶正&#xff0c;所浪费的时间非常影响比赛结果。 如果小豪和小烈可以拥有…

[电子榨菜] js中的闭包closure

0.写在前面: 下学期就打算去实习了,这段时间要密集接收考试和面试的捶打,计网和软工就没有办法为大家继续贡献开源内容了,明年九月份之前的更新内容将会以前端,人工智能,和工程设计为基础, 很抱歉啦,不过我还是希望我这一年来的努力可以帮到一些人.虽然自己这一年过的浑浑噩噩…

Docker容器的优化和性能调优技巧

Docker已经成为了现代应用程序开发和部署的核心工具之一。然而&#xff0c;要确保Docker容器在生产环境中运行稳定、高效&#xff0c;需要一些优化和性能调优的技巧。本文将介绍一些关键的Docker容器优化和性能调优策略&#xff0c;并提供丰富的示例代码&#xff0c;以帮助大家…

【精简】mysql创建自定义函数 sql写法举例

一&#xff0c;举例的sql是查询 某个时间点某个币种的汇率 create function get_rate(idate date,CURRENCY varchar(32)) returns decimal(21,6) begin declare res decimal(21,6) default 1;selec rate into resfromt_exchangerate tewhere ratedate idateand CURRENCYID C…

Apache Pulsar 技术系列 - PulsarClient 实现解析

导语 Apache Pulsar 是一个多租户、高性能的服务间消息传输解决方案&#xff0c;支持多租户、低延时、读写分离、跨地域复制&#xff08;GEO replication&#xff09;、快速扩容、灵活容错等特性。同时为了达到高性能&#xff0c;低延时、高可用&#xff0c;Pulsar 在客户端也…

【Linux C | 文件I/O】文件的打开关闭 | open、creat、colse 函数

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…