MYSQL中DML、DDL常用语句记录

MYSQL中DML、DDL常用语句记录

DML

在 MySQL 中,DML (Data Manipulation Language) 是一类用于查询和操作数据的 SQL 语句。以下是常用的 DML 语句:

1、SELECT

SELECT 语句用于查询数据库中的数据。语法如下:

SELECT column1, column2, ...
FROM table_name
WHERE condition;

其中,column1, column2, ... 是需要查询的列名,可以使用通配符 * (代表所有列)代替。table_name 是要查询的表名。WHERE 子句是可选的,它用于指定查询条件。

2、INSERT

INSERT 语句用于向表中插入新行。语法如下:

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

其中,table_name 是要插入数据的表名,column1, column2, ... 是要插入数据的列名,value1, value2, ... 是要插入的数据值。

-- 单个
INSERT INTO employees(id, first_name, last_name, gender, hire_date, dept_id)
VALUES (101, 'John', 'Doe', 'M', '2020-01-01', 1);
-- 批量插入
INSERT INTO employees(id, first_name, last_name, gender, hire_date, dept_id)
VALUES (101, 'John', 'Doe', 'M', '2020-01-01', 1),(102, 'Jane', 'Doe', 'F', '2020-02-01', 2),(200, 'Alex', 'Lee', 'M', '2020-12-01', 3);-- 使用 INSERT INTO ... SELECT ... 语句插入数据
INSERT INTO employees(id, first_name, last_name, gender, hire_date, dept_id)
SELECT id, first_name, last_name, gender, hire_date, dept_id
FROM temp_employees;

3、UPDATE

UPDATE 语句用于修改表中的数据。语法如下:

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

其中,table_name 是要修改数据的表名,column1 = value1, column2 = value2, ... 是要修改的列名和对应的值,WHERE 子句是可选的,它用于指定修改条件。如果没有指定 WHERE 子句,则会更新表中的所有行。

4、DELETE

DELETE 语句用于删除表中的数据。语法如下:

DELETE FROM table_name
WHERE condition;

其中,table_name 是要删除数据的表名,WHERE 子句是可选的,它用于指定要删除的行的条件。如果没有指定 WHERE 子句,则会删除表中的所有行。

DDL

在 MySQL 中,DDL (Data Definition Language) 是一类用于定义和管理数据库结构及对象的 SQL 语句。以下是常用的 DDL 语句:

1、CREATE TABLE

CREATE TABLE 语句用于在数据库中创建一个新表。语法如下:

CREATE TABLE table_name (column1 data_type constraints,column2 data_type constraints,...table_constraints
);

其中,table_name 是要创建的表名,column1, column2, ... 是要创建的列名和对应的数据类型和约束条件。

2、ALTER TABLE

ALTER TABLE 语句用于修改数据库表的结构。语法如下:

ALTER TABLE table_name action;

其中,table_name 是要修改的表名,action 是要执行的操作,包括添加、删除或修改列等。

示例:

-- 往user表中增加一个名为address的字段,规定了字段的类型,默认值以及注释,并放在了name字段后面。
ALTER TABLE user ADD COLUMN address varchar(256) DEFAULT '' COMMENT '字段注释' AFTER name;
-- 修改
ALTER TABLE user MODIFY COLUMN address varchar(256) DEFAULT '' COMMENT '字段注释';
-- 删除
ALTER TABLE user DROP COLUMN address;

3、DROP TABLE

DROP TABLE 语句用于删除数据库中的一个或多个表。语法如下:

DROP TABLE table_name;

其中,table_name 是要删除的表名。

4、CREATE INDEX

CREATE INDEX 语句用于为数据库表创建一个或多个索引。语法如下:

CREATE INDEX index_name
ON table_name (column1, column2, ...);

其中,index_name 是要创建的索引名称,table_name 是要创建索引的表名,(column1, column2, ...) 是要创建索引的列名。

CREATE INDEX idx_employee_dept_id ON employees(dept_id);

5、DROP INDEX

DROP INDEX 语句用于删除某个表的指定索引。语法如下:

DROP INDEX index_name
ON table_name;

其中,index_name 是要删除的索引名称,table_name 是要删除索引的表名。

DROP INDEX idx_employee_dept_id ON employees;

6、TRUNCATE

truncate语句用于快速清空数据表。与 DELETE 语句不同,TRUNCATE 语句将删除表中所有行,但不会删除表本身。

需要注意的是,与 DELETE 不同,TRUNCATE 在删除数据时不记录在日志中,并且不能回滚(UNDO)。另外,必须具有 DROP 权限才能使用 TRUNCATE 命令。并且使用TRUNCATE 之后表的主键是会重新从零开始的。

7、查看字符集和排序规则

-- 服务器
show variables like 'character_set_server';
show variables like 'collation_server';
-- 数据库
show variables like 'character_set_database';
show variables like 'collation_database';
-- 表
SHOW FULL COLUMNS FROM table_name;

8、设置字符集和排序规则

-- 单独给表设置
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

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

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

相关文章

Kafka(一)在WSL单机搭建Kafka伪集群

目录 1 运行Kafka单实例1.1 Windws1.1.1 安装包下载1.1.2 修改环境变量1.1.3 修改配置文件1.1.4 启动Kafka单机版 1.2 Linux1.2.1 安装包下载1.2.2 创建目录1.2.3 添加环境变量1.2.4 修改配置文件1.2.5 运行Kafka1.2.6 停止Kafka 2 搭建Kafka集群2.1 搭建Zookeeper集群2.2 搭建…

文本转语音:微软语音合成标记语言 (SSML) 文本结构和事件

​ SSML 的语音服务实现基于万维网联合会的语音合成标记语言版本 1.0。 ​ 语音服务支持的元素可能与 W3C 标准不同。 每个 SSML 文档是使用 SSML 元素(或标记)创建的。 这些元素用于调整语音、风格、音节、韵律、音量等。 下面是 SSML 文档的基本结构…

【Linux常用命令】-文件写入相关

一、rm命令,文件删除 1.相关参数 -f(–force):强制删除文件或目录,无需确认。 -r(–recursive):递归地删除目录及其内容。 -i(–interactive):交…

ultrascale FPGA

1.工艺从mos到FIN,查了半天资料,不如bili的intel介绍视频,其实是把DS做成3D结构,减小DS漏电流; 2.型号的尾数是以百万门为标定的; 3.slice(切片)是CLB的组成单元,slice又包含LUT&a…

CANdelaStudio 使用教程5 编辑DID

文章目录 在哪编辑DID的分类编辑快照数据添加 DID 在哪编辑 DID的分类 编辑快照数据 添加 DID

Linux C语言 26-可变参数

Linux C语言 26-可变参数 本节关键字:可变参数、va_list、va_arg、va_end 相关C库函数:va_list、va_arg、va_end 什么是可变参数? C语言中的可变参数是指函数能够接受不定数量的参数。在不确定函数参数时,使用“char *format, …

async函数和await关键字

async写在一个函数a前面,该函数变为异步函数,可在里面使用await关键字,await后面一般跟一个promise对象(axios函数返回一个promise对象,里面有异步任务),await会原地等待该异步任务结果&#xf…

单细胞seurat入门—— 从原始数据到表达矩阵

根据所使用的建库方法,单细胞的RNA序列(也称为读取(reads)或标签(tags))将从转录本的3端(或5端)(10X Genomics,CEL-seq2,Drop-seq&…

枚举的第一行

2023年11月26日 问题: 好奇enum的所声明的枚举类的第一行是什么 从java技术卷1中第五章5.6中,了解是枚举类的实例 验证 错误信息: 解释: 此时只有有参构造 在这个枚举类里不能使用空,大概意思是说不能使用空参创建实例 校验 在原有的基础上创建一个无参构造 结果:不再报错,第…

c语言练习12周(11~15)

编写double fun(int a[],int n)函数,计算返回评分数组a中,n个评委打分,去掉一个最高分去掉一个最低分之后的平均分 题干编写double fun(int a[],int n)函数,计算返回评分数组a中,n个评委打分,去掉一…

php.ini文件中XDebug的配置

[XDebug] zend_extension"G:/php/ext/php_xdebug.dll" xdebug.mode debug xdebug.start_with_request trigger 其中G:/php/ext/php_xdebug.dll为xdebug.dll的文件路径。 原文件格式类似于 php_xdebug-3.3.0alpha3-8.2-vs16-x86_64.dll xdebug官网 Xdebug - Debu…

【教学类-06-13】20231126 (55格版)趣味题(一)1-9加法题(10倍)(整十相加)

作品展示 背景需求: 1、会做加法题的孩子5分钟内完成题目,太快了,所以为了拉平差异,需要给这些会做另外的题目,比如提供一些他们没有做过的“趣味题形”。 2、好多次,听见大班孩子在互相“考试”——“老…

CSS常用笔记

1. 脱离文档流&#xff0c;用于微调 {position: relative; top: 10px; right: 0; } 2. flex布局大法 <div class"demo"><div class"demo-1"></div><div class"demo-2"></div><div class"demo-3"&…

从源码重新真正认识RateLimiter(SmoothBursty实现)

前言 相信大家对于谷歌RateLimiter一定并不陌生,在项目中应该也经常拿来进行限流&#xff0c;但是对于其实现原理并不一定能用熟于心&#xff0c;本文带大家从源码探究RateLimiter的设计与具体实现。 RateLimiter的组成 从源码可以看到&#xff0c;RateLimiter由stopwatch与m…

27、Nuxt.js项目整合ElementUI组件库

参考element-ui官网安装组件库 项目中新建插件引入element-ui plugins\element-ui.js import Vue from vue; import ElementUI from element-ui;Vue.use(ElementUI);nuxt.config.js plugins: ["/plugins/element-ui.js"],build: {// 将位于 node_modules 目录下的…

【go语言实现一个webSocket的一个demo】

go语言实现一个webSocket的一个demo 前端代码 <html lang"zh-CN"><head></head><body> <script type"text/javascript">// header(Access-Control-Allow-Origin:*);var sock null;var wsuri "ws://127.0.0.1:9999&…

Elasticsearch集群部署,配置head监控插件

Elasticsearch是一个开源搜索引擎&#xff0c;基于Lucene搜索库构建&#xff0c;被广泛应用于全文搜索、地理位置搜索、日志处理、商业分析等领域。它采用分布式架构&#xff0c;可以处理大规模数据集和支持高并发访问。Elasticsearch提供了一个简单而强大的API&#xff0c;可以…

全球SAR卫星大盘点与回波数据处理专栏目录

近年来&#xff0c;随着商业航天的蓬勃发展&#xff0c;商业SAR卫星星座成为美欧等主要航天国家的发展重点&#xff0c;目前已在全球范围内涌现出众多初创公司进军商业SAR领域&#xff0c;开始构建大规模商业微小SAR卫星星座&#xff0c;其所具有的创新服务能力将为传统的商业遥…

uniapp IOS从打包到上架流程(详细简单)

​ uniapp IOS从打包到上架流程&#xff08;详细简单&#xff09; 原创 1.登入苹果开发者网站&#xff0c;打开App Store Connect ​ 2.新App的创建 点击我的App可以进入App管理界面&#xff0c;在右上角点击➕新建App 即可创建新的App&#xff0c;如下图&#xff1a; ​ 3.…

VUE简易计划清单

目录 效果预览图 完整代码 效果预览图 完整代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>…