Mysql常见的SQL语句格式及实用技巧

2025-06-24 17:50

本文主要是介绍Mysql常见的SQL语句格式及实用技巧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Mysql常见的SQL语句格式及实用技巧》本文系统梳理MySQL常见SQL语句格式,涵盖数据库与表的创建、删除、修改、查询操作,以及记录增删改查和多表关联等高级查询,同时提供索引优化、事务处理、临时...

一、常用语法汇总

数据库(database)表(table)记录
CREATE DATABASE [IF NOT EXISTS] database_name;CREATE TABLE [IF NOT EXISTS] table_name (
  column1 datatype [constraint],
  column2 datatype [constraint],
  ...
  [PRIMARY KEY (column_list)]
);

-- 插入记录(单条)
INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

-- 插入多条记录
INSERT INTO table_namewww.chinasem.cn (column1, column2, ...)
VALUES (value1_1, value1_2, ...),
       (value2_1, value2_2, ...);

DROP DATABASE [IF EXISTS] database_name;DROP TABLE [IF EXISTS] table_name;DELETE FROM table_name WHERE condition;
-- 切换数据库
USE database_name;
-- 修改表结构(示例:添加列)
ALTER TABLE table_name ADD column_name datatype;
UPDATE table_name
SET column1 = valhttp://www.chinasem.cnue1, column2 = value2, ...
WHERE condition;
SHOW DATABASES;

-- 查看所有表
SHOW TABLES;

-- 查看表结构
DESCRIBE table_name;

-- 查询记录(全量)
SELECT * FROM table_name;

-- 查询特定字段
SELECT column1, column2 FROM table_name;

-- 条件查询
SELECT * FROM table_name WHERE condition;

-- 排序查询
SELECT * FROM table_name ORDER BY column [ASC|DESC];

-- 分页查询(LIMIT 从 0 开始)
SELECT * FROM table_name LIMIT offset, count;

常用约束与修饰符
-- 主键约束(唯一标识)
PRIMARY KEY (column)
-- 唯一约束(值不能重复)
UNIQUE (column)
-- 非空约束
NOT NULL
-- 默认值
DEFAULT value
-- 自增(整数类型)
AUTO_INCREMENT

二、示例

1.数据库操作

-- 创建数据库(存在则跳过)
CREATE DATABASE IF NOT EXISTS db_name;
-- 删除数据库(谨慎使用)
DROP DATABASE IF EXISTS db_name;
-- 查看所php有数据库
SHOW DATABASES;
-- 切换数据库
USE db_name;

2.表操作

(1)创建表

CREATE TABLE IF NOT EXISTS users (
  id INT androidPRIMARY KEY AUTO_INCREMENT,
  name VARCHAR(50) NOT NULL,
  age INT DEFAULT 18,
  email VARCHAR(100) UNIQUE,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

(2)修改表结构

-- 添加列
ALTER TABLE users ADD COLUMN phone VARCHAR(20);
-- 修改列类型
ALTER TABLE users MODIFY COLUMN age TINYINT;
-- 重命名列
ALTER TABLE users CHANGE COLUMjsN phone mobile VARCHAR(20);
-- 删除列
ALTER TABLE users DROP COLUMN mobile;

(3)删除表

DROP TABLE IF EXISTS users;

(4)查看表信息

-- 查看表结构
DESCRIBE users;
-- 查看建表语句
SHOW CREATE TABLE users;

3.记录操作 

(1)插入数据

-- 单条插入
INSERT INTO users (name, age, email)
VALUES ('Alice', 25, 'alice@example.com');
-- 批量插入
INSERT INTO users (name, age)
VALUES ('Bob', 30), ('Charlie', 22);
-- 插入查询结果
INSERT INTO users_backup (name, age)
SELECT name, age FROM users WHERE age > 25;

(2)查询数据

-- 基础查询
SELECT * FROM users;
-- 条件查询
SELECT name, age FROM users WHERE age > 25 AND name LIKE 'A%';
-- 去重查询
SELECT DISTINCT age FROM users;
-- 排序与分页
SELECT * FROM users ORDER BY age DESC LIMIT 10 OFFSET 20;
-- 聚合函数
SELECT COUNT(*), AVG(age), MAX(age) FROM users;
-- 分组查询
SELECT age, COUNT(*) FROM users GROUP BY age HAVING COUNT(*) > 1;

(3)更新数据

-- 单条件更新
UPDATE users SET age = age + 1 WHERE name = 'Alice';
-- 多字段更新
UPDATE users SET age = 30, email = 'bob@new.com' WHERE id = 2;
-- 批量更新(基于子查询)
UPDATE users u
JOIN user_scores s ON u.id = s.user_id
SET u.age = s.age + 5;

(4)删除数据

-- 按条件删除
DELETE FROM users WHERE age < 18;
-- 清空表(保留结构)
TRUNCATE TABLE users;

4.高级查询

(1)多表关联

-- 内连接
SELECT u.name, o.order_id
FROM users u
JOIN orders o ON u.id = o.user_id;
-- 左连接
SELECT u.name, o.order_id
FROM users u
LEFT JOIN orders o ON u.id = o.user_id;

(2)子查询

SELECT * FROM users
WHERE age > (SELECT AVG(age) FROM users);

(3)联合查询

SELECT name FROM users
UNION
SELECT product_name FROM products;

三、实用技巧

1.避免全表扫描:为查询字段添加索引

CREATE INDEX idx_age ON users (age)

2.事务处理:保证数据一致性

START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT; -- 或 ROLLBACK

3.临时表:提升查询效率与隔离性,会话内有效,会话关闭自动删除。

-- 创建临时表并填充数据
CREATE TEMPORARY TABLE temp_orders AS
SELECT order_id, user_id, amount
FROM orders
WHERE create_time > '2023-01-01';
-- 使用临时表进行后续查询
SELECT user_id, SUM(amount)
FROM temp_orders
GROUP BY user_id;

到此这篇关于mysql常见的SQL语句格式的文章就介绍到这了,更多相关mysql sql语句格式内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Mysql常见的SQL语句格式及实用技巧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155199

相关文章

MySQL磁盘空间不足问题解决

《MySQL磁盘空间不足问题解决》本文介绍查看空间使用情况的方式,以及各种空间问题的原因和解决方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录查看空间使用情况Binlog日志文件占用过多表上的索引太多导致空间不足大字段导致空间不足表空间碎片太多导致空间不足临时表空间

MySQL进行分片合并的实现步骤

《MySQL进行分片合并的实现步骤》分片合并是指在分布式数据库系统中,将不同分片上的查询结果进行整合,以获得完整的查询结果,下面就来具体介绍一下,感兴趣的可以了解一下... 目录环境准备项目依赖数据源配置分片上下文分片查询和合并代码实现1. 查询单条记录2. 跨分片查询和合并测试结论分片合并(Shardin

MySQL配置多主复制的实现步骤

《MySQL配置多主复制的实现步骤》多主复制是一种允许多个MySQL服务器同时接受写操作的复制方式,本文就来介绍一下MySQL配置多主复制的实现步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 环境准备2. 配置每台服务器2.1 修改每台服务器的配置文件3. 安装和配置插件4. 启动组复制4.

MySQL数据脱敏的实现方法

《MySQL数据脱敏的实现方法》本文主要介绍了MySQL数据脱敏的实现方法,包括字符替换、加密等方法,通过工具类和数据库服务整合,确保敏感信息在查询结果中被掩码处理,感兴趣的可以了解一下... 目录一. 数据脱敏的方法二. 字符替换脱敏1. 创建数据脱敏工具类三. 整合到数据库操作1. 创建服务类进行数据库

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

MYSQL中information_schema的使用

《MYSQL中information_schema的使用》information_schema是MySQL中的一个虚拟数据库,用于提供关于MySQL服务器及其数据库的元数,这些元数据包括数据库名称、表... 目录关键要点什么是information_schema?主要功能使用示例mysql 中informa

MySQL容灾备份的实现方案

《MySQL容灾备份的实现方案》进行MySQL的容灾备份是确保数据安全和业务连续性的关键步骤,容灾备份可以分为本地备份和远程备份,主要包括逻辑备份和物理备份两种方式,下面就来具体介绍一下... 目录一、逻辑备份1. 使用mysqldump进行逻辑备份1.1 全库备份1.2 单库备份1.3 单表备份2. 恢复

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

MySQL的触发器全解析(创建、查看触发器)

《MySQL的触发器全解析(创建、查看触发器)》MySQL触发器是与表关联的存储程序,当INSERT/UPDATE/DELETE事件发生时自动执行,用于维护数据一致性、日志记录和校验,优点包括自动执行... 目录触发器的概念:创建触www.chinasem.cn发器:查看触发器:查看当前数据库的所有触发器的定

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、