mysql之数据类型、建表以及约束

news2024/10/5 21:17:19

文章目录

  • 一、CRUD
    • 1.1 SELECT(查询)
      • 1.1.1概念
      • 1.1.2语法(这里的''都改为<>)
      • 1.1.3含义(这里的''都改为<>)
    • 1.2 INSERT(新增)
      • 1.2.1概念
      • 1.2.2语法
      • 1.2.3含义
      • 1.2.4 由INSERT 语句的两种形式可以看出:
    • 1.3UPDATE(修改)
      • 1.3.1语法
      • 1.3.2含义
    • 1.4DELETE(删除)
      • 1.4.1语法
      • 1.4.2含义
  • 二、函数
    • 2.1常见函数
      • 2.1.1 字符函数
      • 2.1.2 数字函数
      • 2.1.3 日期函数
    • 2.2流程控制函数
      • 2.2.1 语法
      • 2.2.2 示例
        • 2.2.2.1 查询同时存在”01“课程和”02“课程的情况
        • 2.2.2.2 查询会议信息(包含会议信息表数据,主持人姓名、审批人姓名、会议状态)
    • 2.3聚合函数
  • 三、union与union all
    • 3.1 概念
    • 3.2 语法
    • 3.3 专业词解释
    • 3.4 使用场景
    • 3.5 实例
      • 3.5.1 全列(查全部)
      • 3.5.1.1 初始数据
      • 3.5.1.2 UNION
      • 3.5.1.3 UNION all
      • 3.6 单列(查id)
      • 3.6.1.1 初始数据
      • 3.6.1.2 UNION
      • 3.6.1.3 UNION all
    • 3.6 结论
  • 四、流程图

一、CRUD

1.1 SELECT(查询)

1.1.1概念

查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作.

1.1.2语法(这里的’'都改为<>)

SELECT
{|<字段列名>}
[FROM <表 1>,<表 2>…
[WHERE<表达式>
[GROUP BY ‘group by definition’
[HAVING ‘expression’[(‘operator’ ‘expression’)…]]
[ORDER BY ‘order by definition’]
[LIMIT[‘offset’,] ‘row count’]
]

1.1.3含义(这里的’'都改为<>)

①"{<字段列名>}";包含星号通配符的字段列表,表示所要查询字段的名称
②<表 1>,<表 2>…;表 1 和表2表示查询数据的来源,可以是单个或多个
③WHERE<表达式>;是可选项,如果选择该项,将限定查询数据必须满足该查询条件
④GROUP BY<字段>;该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。
⑤ORDER BY<字段 >;该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
⑥[LIMIT[‘offset’,]‘row count’];该子句告诉 MySQL 每次显示查询出来的数据条数。

1.2 INSERT(新增)

1.2.1概念

使用INSERT 语句向数据库已有的表中插入一行或者多行元组数据

1.2.2语法

①INSERT…VALUES
—INSERTINTO C表名>[<列名1>[,…<列名n>]]VALUES(值1)[…,(值n)]
②INSERT…SET语句
–INSERTINTO<表名>SET<列名1>=值1>,<列名2>=值2>,…

1.2.3含义

①<表名>:指定被操作的表名

②<列名>:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 NSERT<表名>VALUES(…) 即可

③"VALUES"或"VALUE"子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应

1.2.4 由INSERT 语句的两种形式可以看出:

-使用INSERT…VALUES 语可以向表中插入一行数据,也可以插入多行数据
-使用INSERT…SET 语可以指定插入行中每列的值,也可以指定部分列的值;
-INSERT…SELECT 语向表中插入其他表的数据。
-采用INSERT…SET 语句可以向表中插入部分列的值,这种方式更为灵活;
I-NSERT…VALUES 语可以一次插入多条数据。

1.3UPDATE(修改)

1.3.1语法

UPDATE<表名> SET 字段 1=值 1[字段 2=值 2…][WHERE 子][ORDER BY 子句][LIMIT 子句]

1.3.2含义

①<表名>:用于指定要更新的表名称。
②SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT表
示列值。
③WHERE子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行
④ORDER BY子句:可选项。用于限定表中的行被修改的次序
⑤LIMIT子句:可选项。用于限定被修改的行数。

1.4DELETE(删除)

1.4.1语法

DELETE FROM<表名>[WHERE 子][ORDER BY 子][LIMIT 子句]

1.4.2含义

①<表名>:指定要删除数据的表名。
②"ORDER BY"子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除
③"WHERE"子句:可选项。表示为删除操作限定删除条件,若省路该子句,则代表删除该表中的所有行。
④"LIMIT"子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值

二、函数

2.1常见函数

2.1.1 字符函数

  • 转小写 --LOWER(‘SQL Course’)–sql course
  • 转大写 --UPPER(‘SQL Course’)–SQL COURSE
  • 拼接–CONCAT(‘Hello,World’)–HelloWorld
  • 截取–SUBSTR(‘HelloWorid’,1,5)–Hello
  • 长度–LENGTH(‘HelloWorid’)–10
  • 字符出现索引值–INSTR(‘HelloWorld’,‘W’)–6
  • 字符载取后半段–TRIM(‘HFROM HelloWorld’)–elloWorid
  • 字符替换–REPLACE(‘abod’,‘b’,'m”)–amcd

2.1.2 数字函数

  • 四舍五入–ROUND(45.926,2)–45.93
  • 截断–TRUNC(45.926,2)–45.92
  • 求余–MOD(1600,300)–100

2.1.3 日期函数

  • 获取当前日期–now()
  • 将日期格式的字符转换成指定格式的日期–STRTO DATE(‘9- 13-1999’,‘%m-%d-%Y’)–1999-09-13
  • 将日期转换成字符–DATE_FORMAT(2018/6/6,‘Y年%m月%d日’)–2018年06月06日

2.2流程控制函数

2.2.1 语法

CASE expr WHEN comparison_expr1 THEN return_expr1
[WHEN comparison_expr2 THEN return_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END

2.2.2 示例

2.2.2.1 查询同时存在”01“课程和”02“课程的情况

SELECT
t3. * ,
(CASE WHEN t1.cid =01’ THEN t1.score END) 语文,
(CASE WHEN t2.cid =02 THEN 2.score END) 数学
FROM
( SELECTFROM t_mysql_score sc WHERE sc.cid =01’ )t1,
( SELECT
FROM t mysql score sc WHERE sc.cid = 02’ ) t2,
t_mysql student t3
WHERE
t1.sid = t2.sid
AND t1.sid = t3.sid

2.2.2.2 查询会议信息(包含会议信息表数据,主持人姓名、审批人姓名、会议状态)

SELECT a.id,a.title,a.content,a.canyuze,a.liexize,a.zhuchiren,b.‘name’,a.location
,DATE_FORMAT(a.startTime,‘%Y-%m-%d %H:%i:%s’) as startTime
,DATE_FORMAT(a.endTime,‘%Y-%m-%d %H:%i:%s’) as endTime
,a.state
,(case a.state
when 0 then ‘取消会议’
when 1 then ‘新建’
when 2 then ‘待审核’
when 3 then ‘驳回’
when 4 then ‘待开’
when 5 then ‘进行中’
when 6 then ‘开启投票’
else ‘结束会议’ end
) as meetingState
,aseatPic,a.remark,a.auditor,c.‘name’ as auditorName
FROM t_oa_meeting_info a
inner join t_oa_user b on a.zhuchiren = b.id
left JOIN t_oa_user c on a.auditor = c.id where 1=1 ;

2.3聚合函数

sum 求和、avg 平均值、max 最大值、min 最小值 、count 计算个数

三、union与union all

3.1 概念

UNION:用于合井两个或多个SELECT语句的结果集,并去除重复的行UNIONALL:用于合并两个或多个SELECT语句的结果集,包括重复的行。

3.2 语法

  • UNION:将多个SELECT语放在一起,并使用UNION关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型必须相同。
  • UNION ALL:将多个SELECT语句放在一起,并使用UNION ALL关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型可以不同。

3.3 专业词解释

  • UNION:UNION操作符执行去除重复行的操作,它通过对所有的结果集进行排序和比较来实现
  • UNION ALL:UNION ALL操作符不执行去除重复行的操作,它直接将所有的结果集合并在一起

3.4 使用场景

  • UNION:当需要合并多个查询结果,并且不希望出现重复行时,可以使用UNION操作符。它适用于数据需要去重的情况。
  • UNION ALL:当需要合井多个查询结果,包括重复行时,可以使用UNION ALL操作符。它适用于不需要去重的情况,或者在已经确定结果不会有重复行的情况下,

3.5 实例

3.5.1 全列(查全部)

3.5.1.1 初始数据

SELECT* from t_oa_meeting_info where id >= 1 and id <= 8;
SELECT * from t _oa_meeting_info where id >= 6 and id <= 10;

3.5.1.2 UNION

SELECT * from t_oa_meeting_info where id >= 1 and id <= 8
UNION
SELECT * from t oa meeting_info where id >= 6 and id <= 10;

678只出现了1次

3.5.1.3 UNION all

SELECT * from t_oa_meeting_info where id >= 1 and id <= 8
UNION all
SELECT* from t oa_meeting_info where id >= 6 and id <= 10;

678重复出现

3.6 单列(查id)

3.6.1.1 初始数据

SELECT id from t_oa_meeting_info where id >= 1 and id <= 8;
SELECT id from t oa meeting_info where id >= 6 and id <= 10;

3.6.1.2 UNION

SELECT id from t_oa_meeting_info where id >= 1 and id <= 8
UNION
SELECT id from t oa meeting_info where id >= 6 and id <= 10

678只出现了1次

3.6.1.3 UNION all

SELECT id from t_oa_meeting_info where id >= 1 and id <= 8
UNION all
SELECT id from t_oa meeting_info where id >= 6 and id <= 10;

678重复出现

3.6 结论

所谓去重并不需要所有列相同

四、流程图

在这里插入图片描述

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

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

相关文章

Aop编程之动态代理

1、Java代理介绍 Java中的代理方式包括静态代理和动态代理。 静态代理在编译期间就确定了代理对象&#xff0c;动态代理是在运行期间动态生成代理对象。动态代理包括cglib动态代理和jdk动态代理&#xff0c;在目标对象有接口的情况下&#xff0c;可以使用jdk动态代理或者cglib…

PyTorch项目源码学习(2)——Tensor代码结构初步学习

PyTorch版本&#xff1a;1.10.0 Tensor Tensor是Pytorch项目较为重要的一部分&#xff0c;其中的主要功能如存储&#xff0c;运算由C和CUDA实现&#xff0c;本文主要从前端开始探索学习Tensor的代码结构。 结构探索 PyTorch前端位于torch目录下&#xff0c;从_tensor.py可以…

手持终端PDA定制厂家_5G安卓手持机设备/条形码扫描手持机PDA

手持终端PDA是一种功能强大的手持终端设备&#xff0c;具备一维码和二维码扫描功能&#xff0c;广泛应用于门票管理、零售、智能巡检、仓储物资管理、金融、快递等领域。 这款手持终端基于MT6877方案&#xff0c;搭载八核处理器(2xCortex-A78 2.4GHz 6xCortex-A55 2.0GHz)&…

【机器学习前置知识】狄利克雷分布

在阅读本文前&#xff0c;建议先食用以下几篇文章以能更好地理解狄利克雷分布&#xff1a; 二项分布 Beta分布 多项分布 共轭分布 狄利克雷分布 狄利克雷分布(Dirichlet distribution)是Beta分布的扩展&#xff0c;把Beta分布从二元扩展到多元形式就是狄利克雷分布&#…

【PixPin】比Snipaste、QQ的截图长图和动图还好用的截图工具

1.下载地址—— 下载地址 2.下载压缩包 双击exe文件运行 按默认的来 中文安装 选择安装路径 下一步&#xff0c;安装 安装完成&#xff0c;可以自己设置快捷键

使用Django框架自带的Form表单完成简单的用户登录注册

如果不知道怎么配置Django环境以及如何连接数据库请点击我的上一篇博客&#xff1a; 使用pycharm初始化Django框架并连接Sql Server 文章目录 1.Django默认生成的数据表2.用户登录2.1创建登录页面2.2视图处理登录请求2.3配置访问路径 3.用户注册3.1创建用户表单3.2创建注册模版…

VScode代码格式化

Vscode代码格式化 有时候总是想,为什么我的代码格式化完后为什么这么挤,而且不想让代码在格式化后换行,他总是自动换行,所以我去网上查了相关资料 第一步,搜索插件ESLint并安装,安装完成后你就可以进行格式化了 第二步,设置中选择settings,搜索Tab size,根据一下图片更改 第…

全志T113开发板Qt远程调试

1引言 通常情况下工程师在调试Qt程序时&#xff0c;需要频繁制作镜像烧录到核心板来测试Qt程序是否完善&#xff0c;这样的操作既费时又费力。这时我们可以通过QtCreator设备功能&#xff0c;定义设备后&#xff0c;在x86_64虚拟机上交叉编译qt程序&#xff0c;将程序远程部署到…

ubuntu 18.04网络问题

ubuntu 18.04网络问题汇总 准备工作一、有线网卡不可用二、无法访问外网 准备工作 安装好系统之后&#xff0c;检查gcc和make是否已经安装 $ which gcc /usr/bin/gcc $ which make /usr/bin/make如果未安装&#xff0c;则安装gcc和make $ apt install gcc $ apt install mak…

Golang协程池ants库的学习、使用及源码阅读,协程池与GMP模型关系的理解

前言 在工作时遇到了一个需要使用ants协程池的地方&#xff0c;因此顺带来学习一下他的原理。 协程池 Golang的资源还是偏少一些…因此先简单的参考学习了一下线程池。 类似于Java中的线程池&#xff0c;协程池也是为了减少协程频繁创建、销毁所带来资源消耗的问题。按默认每…

【我想开发一个小程序,大概需要多少钱?】

小程序开发为什么报价差距很大&#xff1f;主要是因为小程序的实现方法和功能模型不同。 小程序的实现方法&#xff1a; 实现方法主要分为SAAS小程序、定制小程序和第三方平台小程序。不同的实现方法价格都是不一样的&#xff0c;大概的区间如下&#xff1a; SAAS小程序和第三…

ChatGPT+Python近红外光谱数据分析及机器学习与深度学习建模进阶应用

目录 第一章 ChatGPT4入门基础 第二章 ChatGPT4 提示词使用方法与技巧 第三章 ChatGPT4助力信息检索与总结分析 第四章 ChatGPT4助力论文写作与投稿 第五章 ChatGPT4助力Python入门基础 第六章 ChatGPT4助力近红外光谱数据预处理 第七章 ChatGPT4助力多元线性回归近红外…

leetcode经典【双指针】例题

删除有序数组中的重复项&#xff1a; https://leetcode.cn/problems/remove-duplicates-from-sorted-array/ 解题思路&#xff1a; 首先注意数组是有序的&#xff0c;那么重复的元素一定会相邻。 注: 要求删除重复元素&#xff0c;实际上就是将不重复的元素移到数组的左侧。 考…

ubuntu20.04安装cuda11.4以及cudnn

系统&#xff1a;ubuntu20.04硬件配置&#xff1a;GPU3080、CPU未知通过《软件和更新》在附加驱动选项中添加了驱动&#xff1a; 1.检查自己电脑支持的cuda nvidia-smi4. 下载cuda11.4.2 wget https://developer.download.nvidia.com/compute/cuda/11.4.2/local_installers/c…

典型的无人机打击技术

无人机打击技术主要指的是用于中和、摧毁或干扰无人机&#xff08;UAV&#xff09;的各种技术手段。 这些技术随着无人机的广泛使用而迅速发展&#xff0c;特别是在军事和安全领域。下面是一些主要的无人机打击技术及其原理&#xff1a; 射频干扰&#xff08;RF Jamming&#x…

算法通关村番外篇-LeetCode编程从0到1系列六

大家好我是苏麟 , 今天带来LeetCode编程从0到1系列六 . 链表相关的题目 , 也是面试热题 . 大纲 21. 合并两个有序链表206. 反转链表 21. 合并两个有序链表 描述 : 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 题目 : Le…

苹果手机设置静态IP教程,长效IP代理有什么帮助?

随着智能手机的普及&#xff0c;越来越多的人开始使用苹果手机。然而&#xff0c;有时候我们在使用苹果手机时&#xff0c;可能会遇到需要设置静态IP的情况。那么&#xff0c;如何在苹果手机上设置静态IP呢&#xff1f;下面就为大家详细介绍一下。 1、打开苹果手机&#xff0c;…

LINUX基础第十一章:文件系统与日志服务管理

目录 一.LINUX文件系统 1.inode表和block &#xff08;1&#xff09;inode &#xff08;2&#xff09;block 2.查看inode号命令 3.Linux系统文件三种主要时间属性 4.磁盘空间还剩余很多但无法继续创建文件 5.inode大小 二.日志 1.日志保存位置 2.日志文件的分类 &am…

关于java的稀疏数组

关于java的稀疏数组 我们在前面的文章中了解了冒泡排序和优化冒泡排序&#xff0c;在本篇文章中我们来介绍一下稀疏数组&#xff0c;我们学会了可以自己动手试一试&#x1f600; 稀疏数组 在介绍稀疏数组之前&#xff0c;我们先来了解一下五子棋。 我们这里有一个11 x 11的棋…

新手练习项目 4:简易2048游戏的实现(C++)

名人说&#xff1a;莫听穿林打叶声&#xff0c;何妨吟啸且徐行。—— 苏轼《定风波莫听穿林打叶声》 Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#xff09; 目录 一、效果图二、代码&#xff08;带注释&#xff09;三、说明 一、效果图 二、代码&#xff08;带…