SQL 基本操作 | PingCAP Docs


本站和网页 https://docs.pingcap.com/zh/tidb/v4.0/basic-sql-operations 的作者无关,不对其内容负责。快照谨为网络故障时之索引,不代表被搜索网站的即时页面。

SQL 基本操作 | PingCAP Docs文档中心TiDB免费试用社区联系我们语言​​v4.0文档中心关于 TiDB快速上手快速上手指南SQL 基本操作部署集群数据迁移运维操作监控与告警故障诊断性能调优教程TiDB 工具参考指南常见问题解答 (FAQ)版本发布历史术语表重要你正在查看 TiDB 数据库的较旧版本 (TiDB v4.0) 的文档。如无特殊需求,建议使用 TiDB 数据库的最新 LTS 版本。SQL 基本操作成功部署 TiDB 集群之后,便可以在 TiDB 中执行 SQL 语句了。因为 TiDB 兼容 MySQL,你可以使用 MySQL 客户端连接 TiDB,并且大多数情况下可以直接执行 MySQL 语句。SQL 是一门声明性语言,它是数据库用户与数据库交互的方式。它更像是一种自然语言,好像在用英语与数据库进行对话。本文档介绍基本的 SQL 操作。完整的 SQL 语句列表,参见 TiDB SQL 语法详解。分类SQL 语言通常按照功能划分成以下的 4 个部分:DDL (Data Definition Language):数据定义语言,用来定义数据库对象,包括库、表、视图和索引等。DML (Data Manipulation Language):数据操作语言,用来操作和业务相关的记录。DQL (Data Query Language):数据查询语言,用来查询经过条件筛选的记录。DCL (Data Control Language):数据控制语言,用来定义访问权限和安全级别。常用的 DDL 功能是对象(如表、索引等)的创建、属性修改和删除,对应的命令分别是 CREATE、ALTER 和 DROP。查看、创建和删除数据库TiDB 语境中的 Database 或者说数据库,可以认为是表和索引等对象的集合。使用 SHOW DATABASES 语句查看系统中数据库列表:SHOW DATABASES;
使用名为 mysql 的数据库:USE mysql;
使用 SHOW TABLES 语句查看数据库中的所有表。例如:SHOW TABLES FROM mysql;
使用 CREATE DATABASE 语句创建数据库。语法如下:CREATE DATABASE db_name [options];
例如,要创建一个名为 samp_db 的数据库,可使用以下语句:CREATE DATABASE IF NOT EXISTS samp_db;
添加 IF NOT EXISTS 可防止发生错误。使用 DROP DATABASE 语句删除数据库。例如:DROP DATABASE samp_db;
创建、查看和删除表使用 CREATE TABLE 语句创建表。语法如下:CREATE TABLE table_name column_name data_type constraint;
例如,要创建一个名为 person 的表,包括编号、名字、生日等字段,可使用以下语句:CREATE TABLE person (
id INT(11),
name VARCHAR(255),
birthday DATE
);
使用 SHOW CREATE 语句查看建表语句,即 DDL。例如:SHOW CREATE TABLE person;
使用 DROP TABLE 语句删除表。例如:DROP TABLE person;
创建、查看和删除索引索引通常用于加速索引列上的查询。对于值不唯一的列,可使用 CREATE INDEX 或 ALTER TABLE 语句创建普通索引。例如:CREATE INDEX person_id ON person (id);
或者:ALTER TABLE person ADD INDEX person_id (id);
对于值唯一的列,可以创建唯一索引。例如:CREATE UNIQUE INDEX person_unique_id ON person (id);
或者:ALTER TABLE person ADD UNIQUE person_unique_id (id);
使用 SHOW INDEX 语句查看表内所有索引:SHOW INDEX FROM person;
使用 ALTER TABLE 或 DROP INDEX 语句来删除索引。与 CREATE INDEX 语句类似,DROP INDEX 也可以嵌入 ALTER TABLE 语句。例如:DROP INDEX person_id ON person;
ALTER TABLE person DROP INDEX person_unique_id;
注意:DDL 操作不是事务,在执行 DDL 时,不需要对应 COMMIT 语句。常用的 DML 功能是对表记录的新增、修改和删除,对应的命令分别是 INSERT、UPDATE 和 DELETE。记录的增删改使用 INSERT 语句向表内插入表记录。例如:INSERT INTO person VALUES(1,'tom','20170912');
使用 INSERT 语句向表内插入包含部分字段数据的表记录。例如:INSERT INTO person(id,name) VALUES('2','bob');
使用 UPDATE 语句向表内修改表记录的部分字段数据。例如:UPDATE person SET birthday='20180808' WHERE id=2;
使用 DELETE 语句向表内删除部分表记录。例如:DELETE FROM person WHERE id=2;
注意:UPDATE 和 DELETE 操作如果不带 WHERE 过滤条件是对全表进行操作。DQL 数据查询语言是从一个表或多个表中检索出想要的数据行,通常是业务开发的核心内容。查询数据使用 SELECT 语句检索表内数据。例如:SELECT * FROM person;
在 SELECT 后面加上要查询的列名。例如:SELECT name FROM person;
+------+
| name |
+------+
| tom |
+------+
使用 WHERE 子句,对所有记录进行是否符合条件的筛选后再返回。例如:SELECT * FROM person WHERE id<5;
常用的 DCL 功能是创建或删除用户,和对用户权限的管理。创建、授权和删除用户使用 CREATE USER 语句创建一个用户 tiuser,密码为 123456:CREATE USER 'tiuser'@'localhost' IDENTIFIED BY '123456';
授权用户 tiuser 可检索数据库 samp_db 内的表:GRANT SELECT ON samp_db.* TO 'tiuser'@'localhost';
查询用户 tiuser 的权限:SHOW GRANTS for tiuser@localhost;
删除用户 tiuser:DROP USER 'tiuser'@'localhost';
下载 PDF文档反馈社区交流本页导航分类查看、创建和删除数据库创建、查看和删除表创建、查看和删除索引记录的增删改查询数据创建、授权和删除用户本页导航文档内容是否有帮助?产品TiDB资源快速上手最佳实践常见问题解答版本发布学习客户案例PingCAP EducationTiDB in Action支持TiDB 社区联系我们公司关于我们招贤纳士新闻报道博客© 2022 PingCAP. All Rights Reserved.