【MySQL】基础语法总结
MySQL 基础语句
一、DDL 数据库定义语言
1.1CREATE 创建
1.1.1 创建数据库
语法结构
CREATE DATABASE database_name;
示例
CREATE DATABASE demo;
1.1.2 创建表
语法结构
CREATE TABLE 表名 (列1 数据类型,列2 数据类型,...
);
示例
CREATE TABLE new_user (id INT PRIMARY KEY,name VARCHAR(50),age INT
);
1.1.3 创建视图
语法格式
create view <视图名> as select查询语句
示例
create view user_view as select id,user_id,user_name from `user`select * from user_view
1.1.4 创建索引
索引名建议以 idx开头。
语法格式
CREATE INDEX 索引名 ON 表名 (列名);
示例
CREATE INDEX idx_user_id ON user (user_id);
可通过explain进行验证
explain select * from user where user_id = 'wu'

1.2 ALTER 修改
1.2.1 添加列
语法结构
ALTER TABLE 表名 ADD 列名 数据类型;
示例
ALTER TABLE user ADD age int(11) DEFAULT null COMMENT '年龄';
1.2.2 删除列
语法结构
ALTER TABLE 表名 DROP 列名;
示例
ALTER TABLE user DROP user_age;
1.2.3 修改列名
语法结构
ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型;
示例
ALTER TABLE user CHANGE age user_age int(11) DEFAULT null COMMENT '新年龄';
1.2.4 修改列数据类型
语法结构
ALTER TABLE 表名 MODIFY 列名 新数据类型;
示例
ALTER TABLE user MODIFY user_age varchar(16);
1.2.5 修改表名
语法结构
ALTER TABLE 表名 RENAME TO 新表名;
示例
ALTER TABLE user RENAME TO new_user;
1.2.6 创建索引
语法结构
ALTER TABLE 表名 ADD INDEX 索引名 (列名);
示例
ALTER TABLE user ADD INDEX idx_user_id (user_id);
1.2.7 删除索引
语法结构
ALTER TABLE 表名 DROP INDEX 索引名;
示例
ALTER TABLE user DROP INDEX idx_user_id;
1.3 DROP 删除
1.3.1 删除库
语法结构
DROP DATABASE 数据库名称
示例
DROP DATABASE demo
1.3.2 删除表
语法结构
DROP TABLE 表名;
示例
DROP TABLE new_user;
1.3.3 删除视图
语法结构
DROP VIEW view_name;
示例
DROP VIEW user_view;
二、DML 数据库操作语言
2.1 INSERT
2.1.1 插入单条
INSERT INTO USER (user_id,user_name,create_time,dept_id) VALUES('sa','saname',now(),1)
2.1.2 插入多条
INSERT INTO USER (user_id,user_name,create_time,dept_id
)
VALUES('sa1', 'saname1', now(), 1),('sa2', 'saname2', now(), 1),('sa3', 'saname3', now(), 1)
2.2 UPDATE
UPDATE USER
SET dept_id = 2
WHEREuser_id = 'sa2'
2.3 DELETE
delete from user where user_id = 'sa1'
三、DQL 数据库查询语言
3.1 基础语法结构
select <列名>
from <表名>
where <筛选条件>
group by <列名>
having <聚合筛选条件>
order by <排序字段>
limit <条数限制>
3.2 常见的查询语句
3.2.1 条件查询
大于、小于、不等于
大于
select * from user where id > 5
小于
select * from user where id < 5
不等于
select * from user where id != 5select * from user where id <> 5
BETWEEN 介于两者范围之内
注意:是包括在内,如下所示 大于等于,而不是大于
select * from user where id BETWEEN 1 and 3
select * from user where id >=1 and id <=3
In 在某个范围之内
select * from user where id in (1,2,4)
3.2.2 逻辑查询
AND
select * from user where id = 2 and user_id = 'wu'
OR
select * from user where id =1 or user_id = 'wu'
3.2.3 DISTINCT 查询不重复
select DISTINCT(user_name) from user
3.2.4 Like 模糊查询
select * from user where user_id like 'sa%'
3.2.5 Order 排序
倒序
select * from user order by id DESC
顺序
select * from user order by id ASC
3.2.6 GROUP BY 分组
select * from user GROUP BY dept_id
3.2.7 HAVING 分组限制
select * from user GROUP BY dept_id HAVING id > 1
3.2.8 LIMIT 限制条数
select * from user limit 0,10;select * from user limit 1;
3.3 连接查询
3.3.1 内连接

SELECT*
FROMUSER t1
INNER JOIN dept t2 ON t1.dept_id = t2.id
3.3.2 全连接
查询出左表和右表所有数据,但是去除两表的重复数据;

SELECT*
FROMUSER t1
FULL JOIN dept t2 ON t1.dept_id = t2.id
以上代码执行会出现错误,因为MYSQL 不支持全连接!!!
3.3.3 左连接
左连接是左边表的所有数据都有显示出来,右边的表数据只显示共同有的那部分,没有对应的部分只能补空显示,所谓的左边表其实就是指放在left join的左边的表;

select * from user t1 left join dept t2 on t1.dept_id = t2.id
3.3.4 右连接
右连接正好是和左连接相反的,这里的右边也是相对right join来说的,在这个右边的表就是右表;

select * from user t1 right join dept t2 on t1.dept_id = t2.id
3.4 常用函数
3.4.1 聚合函数
count
示例
select count(1) from userselect count(*) from userselect count(id) from user
sum
示例
select sum(id) from user
max、min
示例
select max(id) from userselect min(id) from user
3.4.2 LENGTH 字符长度
示例
select user_id , LENGTH(user_id) from user
3.4.3 CASE WHEN 分支函数
语法结构
CASE WHEN condition1 THEN result1WHEN condition2 THEN result2...ELSE result
END
示例
SELECTCASE WHEN dept_id is NULL THEN '无部门'ELSE '有部门'END as DeptId,user_id,user_nameFROMUSER;
相关文章:
【MySQL】基础语法总结
MySQL 基础语句 一、DDL 数据库定义语言 1.1CREATE 创建 1.1.1 创建数据库 语法结构 CREATE DATABASE database_name;示例 CREATE DATABASE demo;1.1.2 创建表 语法结构 CREATE TABLE 表名 (列1 数据类型,列2 数据类型,... );示例 CREATE TABLE new_user (id INT PRIMARY KE…...
【玩玩Vue】使用el-menu作为菜单时,通过一二级路由控制菜单高亮
原文作者:我辈李想 版权声明:文章原创,转载时请务必加上原文超链接、作者信息和本声明。 文章目录 前言一、Vue路由二、路由一级控制高亮(常用)1.vue中路由文件2.网址样式3.Vue文件4.$route的内容 三、路由二级控制高亮…...
9.2 【C语言】使用结构体数组
一个结构体变量中可以存放一组有关联的数据(如一个学生的学号、姓名、成绩等数据),如果有10个学生需要参加运算,显然应该用数组,这就是结构体数组。 9.2.1 定义结构体数组 例9.3 有三个候选人,每个选民只…...
leetcode原题: 最小值、最大数字
题目1:最小值 给定两个整数数组a和b,计算具有最小差绝对值的一对数值(每个数组中取一个值),并返回该对数值的差 示例: 输入:{1, 3, 15, 11, 2}, {23, 127, 235, 19, 8} 输出:3&…...
Prompt2Model: Generating Deployable Models from Natural Language Instructions
本文是LLM系列文章,针对《 Prompt2Model: Generating Deployable Models from Natural Language Instructions》的翻译。 Prompt2Model:从自然语言指令生成可部署模型 摘要1 引言2 Prompt2Model框架3 参考实现4 实验设置5 实验结果6 讨论与结论不足道德…...
前端埋点 sendBeacon 替代方式
看英文文档真的很重要 sendBeacon 限制比较多, 容易跨域, 跨域时候还必须指定请求头, 不能使用通配符来解决跨域 文档地址 文档里面说 fetch 其实可以代替 sendBeacon 原文: Note: For use cases that need the ability to send requests with methods other than POST, or …...
面试官问我MySQL和MariaDB的联系和区别,这我能不知道?
🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师…...
1.网络空间搜素引擎
网络空间搜素引擎 https://cybermap.kaspersky.com/cn 世界所以带有ip的网络设备互联组成的空间叫做网络空间 地址 :shodan.io 简介 : 这句话还是有点东西得 。 区别: 平常得搜素引擎主要搜网页,shadan可以搜所以带有ip地址…...
《安富莱嵌入式周报》第321期:开源12导联便携心电仪,PCB AI设计,150M示波器差分探头,谷歌全栈环境IDX,微软在Excel推出Python
周报汇总地址:嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 视频版: https://www.bilibili.com/video/BV1ju4y1D7A8/ 《安富莱嵌入式周报》第321期:开源12导…...
前端开发必备的网站
前端开发必备的网站及官网 说明: 这里记录了我本人平时开发所用到的网站,对我还是有帮助的,后续会接着补充进来,一方面是为了记录,另一方面也可以帮助到大家… 网站名称及描述网址Elememt-ui (组件库)Elememt-ui&…...
Java运行时jar时终端输出的中文日志是乱码
运行Jar时在控制台输出的中文日志全是乱码,这是因为cmd/bash默认的编码是GBK,只要把cmd的编码改成UTF-8即可 两种方式修改:临时修改和注册表永久修改 临时修改 只对当前的cmd页面有效,关闭后重新打开都会恢复成GBK, 打开cmd&am…...
Vue框架--Vue中el和data的两种写法
data与el的2种写法 1.el有2种写法 (1).new Vue时候配置el属性。 (2).先创建Vue实例,随后再通过vm.$mount(#root)指定el的值。 2.data有2种写法 (1).对象式 (2).函数式 如何选择:目前哪种写法都可以,以后学习到组件时ÿ…...
【数据结构】 二叉树面试题讲解->贰
文章目录 🌏引言🎄[二叉树遍历](https://www.nowcoder.com/practice/4b91205483694f449f94c179883c1fef?tpId60&&tqId29483&rp1&ru/activity/oj&qru/ta/tsing-kaoyan/question-ranking)🐱👤题目描述&#…...
C和SystemVerilog联合仿真
想要联合仿真一个c程序和verilog表示的硬件,可以用如下方法(DPI): 先写一个.c文件funcs.c #include <stdio.h> #include "svdpi.h"extern int sayHello();void something() {printf("something\n");s…...
15-mongodb
一、 MongoDB 简介 1 什么是 MongoDB MongoDB 是一个基于分布式文件存储的数据库。由 C语言编写。在为 WEB 应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系…...
CSS学习笔记02
CSS笔记02 美化网页元素 为什么要美化网页 目的: 有效的传递页面信息美化网页、页面漂亮、才能吸引用户突显页面的主题提高用户的体验 span标签 span标签是短语内容的通用行内容器,它本身并没有任何特殊语义。 通常我们使用span标签来把我们想要重…...
为什么Java接口可以多继承,而类不可以?
个人主页:金鳞踏雨 个人简介:大家好,我是金鳞,一个初出茅庐的Java小白 目前状况:22届普通本科毕业生,几经波折了,现在任职于一家国内大型知名日化公司,从事Java开发工作 我的博客&am…...
自动化信息收集工具 水泽 使用教程
自动化信息收集工具 水泽 使用教程 1.水泽简介&安装2.使用教程3.测试使用1.水泽简介&安装 一条龙服务,只需要输入根域名即可全方位收集相关资产,并检测漏洞。也可以输入多个域名、C段IP等 开发语言:Python3 水泽下载地址 安装前置准备: 当前用户对该目录有写权…...
2023年全国职业院校技能大赛(高等职业教育组)“信息安全管理与评估”理论技能答案
理论技能与职业素养(100分) 2023年全国职业院校技能大赛(高等职业教育组) “信息安全管理与评估”理论技能 【注意事项】 1.理论测试前请仔细阅读测试系统使用说明文档,按提供的账号和密码登录测试系统进行测试&am…...
MATLAB 动态图GIF
MATLAB 动态图GIF 前言一、创建动态图(动态曲线、动态曲面)1. 创建动画曲线(MATLAB animatedline函数)2. 创建动画曲面 二. 保存动态图三、完整示例1. 动态曲线( y s i n ( x ) ysin(x) ysin(x))2. 动态曲…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?
编辑:陈萍萍的公主一点人工一点智能 未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战,在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...
安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...
技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...
【Go语言基础【12】】指针:声明、取地址、解引用
文章目录 零、概述:指针 vs. 引用(类比其他语言)一、指针基础概念二、指针声明与初始化三、指针操作符1. &:取地址(拿到内存地址)2. *:解引用(拿到值) 四、空指针&am…...
基于Springboot+Vue的办公管理系统
角色: 管理员、员工 技术: 后端: SpringBoot, Vue2, MySQL, Mybatis-Plus 前端: Vue2, Element-UI, Axios, Echarts, Vue-Router 核心功能: 该办公管理系统是一个综合性的企业内部管理平台,旨在提升企业运营效率和员工管理水…...
