news 2026/4/29 5:58:13

常用的 SQL 语句分类及其语法:

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
常用的 SQL 语句分类及其语法:

好的,以下是常用的 SQL 语句分类及其语法:

1. 数据查询 (SELECT)

  • 基本查询:
    SELECT 列名1, 列名2, ... FROM 表名;
    • 查询所有列:SELECT * FROM 表名;
    • 查询表数据:SELECT COUNT(*) FROM 表名
  • 带条件查询 (WHERE):
    SELECT 列名1, 列名2, ... FROM 表名 WHERE 条件;
    • 条件运算符:=,!=<>,>,<,>=,<=
    • 逻辑运算符:AND,OR,NOT
    • 范围查询:BETWEEN 值1 AND 值2
    • 列表匹配:IN (值1, 值2, ...)
    • 模糊匹配:LIKE '模式'(通配符%代表任意多个字符,_代表一个字符)
    • 空值判断:IS NULL,IS NOT NULL
  • 结果排序 (ORDER BY):
    SELECT 列名1, 列名2, ... FROM 表名 ORDER BY 排序列1 [ASC|DESC], 排序列2 [ASC|DESC], ...;
    • ASC升序 (默认),DESC降序。
  • 结果去重 (DISTINCT):
    SELECT DISTINCT 列名 FROM 表名;
  • 结果限制 (LIMIT):
    SELECT 列名1, 列名2, ... FROM 表名 LIMIT 数量; -- 取前 N 条 SELECT 列名1, 列名2, ... FROM 表名 LIMIT 偏移量, 数量; -- 分页常用
  • 聚合函数 (GROUP BY, HAVING):
    SELECT 聚合函数(列名), 分组列 FROM 表名 GROUP BY 分组列 HAVING 分组后条件;
    • 常用聚合函数:COUNT(),SUM(),AVG(),MAX(),MIN()
    • GROUP BY按指定列分组。
    • HAVING对分组后的结果进行过滤 (类似WHERE,但作用于分组)。
  • 表连接 (JOIN):
    • 内连接 (INNER JOINJOIN):
      SELECT 列名 FROM 表1 INNER JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 左外连接 (LEFT JOINLEFT OUTER JOIN):
      SELECT 列名 FROM 表1 LEFT JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 右外连接 (RIGHT JOINRIGHT OUTER JOIN):
      SELECT 列名 FROM 表1 RIGHT JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 全外连接 (FULL JOINFULL OUTER JOIN):
      SELECT 列名 FROM 表1 FULL JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 交叉连接 (CROSS JOIN):
      SELECT 列名 FROM 表1 CROSS JOIN 表2;

2. 数据操作 (INSERT, UPDATE, DELETE)

  • 插入数据 (INSERT):
    INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...); -- 插入单条 INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), ...; -- 插入多条 INSERT INTO 表名 SELECT 列名1, 列名2, ... FROM 另一表名 [WHERE 条件]; -- 从查询结果插入
  • 更新数据 (UPDATE):
    UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2, ... WHERE 条件; -- 一定要加WHERE条件避免全表更新!
  • 删除数据 (DELETE):
    DELETE FROM 表名 WHERE 条件; -- 一定要加WHERE条件避免清空表!
  • 清空表数据 (TRUNCATE):
    TRUNCATE TABLE 表名; -- 删除所有数据,重置自增ID等,速度快但不可回滚

3. 数据定义 (CREATE, ALTER, DROP)

  • 创建数据库:
    CREATE DATABASE 数据库名;
  • 删除数据库:
    DROP DATABASE 数据库名;
  • 创建表:
    CREATE TABLE 表名 ( 列名1 数据类型 [约束], 列名2 数据类型 [约束], ... [表级约束] );
    • 常用数据类型:INT,VARCHAR(长度),TEXT,DATE,DATETIME,DECIMAL(总位数, 小数位数),BOOLEAN等。
    • 常用约束:
      • PRIMARY KEY(主键)
      • NOT NULL(非空)
      • UNIQUE(唯一)
      • FOREIGN KEY (外键列) REFERENCES 主表名(主键列)(外键)
      • CHECK (条件)(检查约束)
      • DEFAULT 默认值(默认值)
  • 修改表结构 (ALTER):
    ALTER TABLE 表名 ADD 列名 数据类型 [约束]; -- 添加列 ALTER TABLE 表名 DROP COLUMN 列名; -- 删除列 ALTER TABLE 表名 MODIFY COLUMN 列名 新数据类型 [新约束]; -- 修改列定义 ALTER TABLE 表名 RENAME COLUMN 旧列名 TO 新列名; -- 重命名列 (部分数据库) ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束定义; -- 添加约束 (如外键) ALTER TABLE 表名 DROP CONSTRAINT 约束名; -- 删除约束
  • 删除表:
    DROP TABLE 表名;

4. 数据控制 (GRANT, REVOKE)

  • 授予权限:
    GRANT 权限列表 ON 数据库对象 TO 用户或角色 [WITH GRANT OPTION];
    • 权限列表:SELECT,INSERT,UPDATE,DELETE,ALL PRIVILEGES等。
    • 数据库对象:表名,视图名,数据库名.*等。
  • 撤销权限:
    REVOKE 权限列表 ON 数据库对象 FROM 用户或角色;

5. 其他常用

  • 创建视图 (VIEW):
    CREATE VIEW 视图名 AS SELECT 语句;
  • 创建索引 (INDEX):
    CREATE INDEX 索引名 ON 表名 (列名); -- 单列索引 CREATE INDEX 索引名 ON 表名 (列名1, 列名2); -- 组合索引
    • 索引可加速查询,但会增加插入、更新、删除的开销,需权衡使用。

这些是 SQL 中最常用的一些语句。具体语法细节可能因数据库管理系统(如 MySQL, PostgreSQL, SQL Server, Oracle)的不同而略有差异。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 6:15:46

ECM CCP

Cross-Component Prediction (CCP) Merge Mode Candidate Selection即&#xff1a;跨分量预测&#xff08;色度基于亮度残差建模&#xff09;的合并模式候选列表构建机制。一、背景&#xff1a;什么是 CCP&#xff1f; ✅ 跨分量预测&#xff08;Cross-Component Prediction, C…

作者头像 李华
网站建设 2026/4/28 8:19:17

2025可观测平台选型指南:全球领先厂商综合对比与推荐

引言&#xff1a;为什么企业需要可观测平台&#xff1f; 随着数字化转型深入&#xff0c;企业IT系统日益复杂&#xff0c;微服务、容器化、多云架构成为常态。传统监控手段已难以实现对系统状态的全面洞察。根据Gartner预测&#xff0c;到2027年&#xff0c;超过50%的企业将依…

作者头像 李华
网站建设 2026/4/28 16:13:38

数字世界的“骨架”:一篇文章教会你查看目录树形结构

&#x1f4c1; 数字世界的“骨架”&#xff1a;一篇文章教会你查看目录树形结构无论你使用哪种操作系统&#xff0c;目录树都是文件世界的骨架&#xff0c;掌握了它&#xff0c;你就掌握了数字世界的导航图&#x1f333; 先来认识一下&#xff1a;什么是目录树&#xff1f; 想象…

作者头像 李华
网站建设 2026/4/24 8:27:06

70、深入探究 Linux 系统安全技术

深入探究 Linux 系统安全技术 1. 用户账户监控 用户账户常被用于对系统的恶意攻击,攻击者可能通过未经授权访问现有账户、创建新的虚假账户或留下账户以便日后访问。为避免此类安全问题,监控用户账户至关重要。 1.1 检测假冒新账户和特权 未经适当授权创建的账户应被视为…

作者头像 李华
网站建设 2026/4/25 14:03:10

EtherCAT主站协议栈EC-Master在ROS(机器人操作系统)中的应用

机器人操作系统&#xff08;ROS&#xff09;是一个开源框架和软件库集合&#xff0c;专门用于简化机器人应用的开发。尽管名称中含“操作系统”&#xff0c;但ROS并非像Windows或Linux那样的真正操作系统&#xff0c;而是通常被称为元操作系统或中间件层。它通常运行在宿主操作…

作者头像 李华