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语句查看系统中数据库列表:


              
SHOWDATABASES;

使用名为mysql的数据库:


              
USE mysql;

使用SHOW TABLES语句查看数据库中的所有表。例如:


              
SHOWTABLESFROMmysql;

使用创建DATABASE语句创建数据库。语法如下:


              
创建DATABASE db_name [options];

例如,要创建一个名为samp_db的数据库,可使用以下语句:


              
创建DATABASE IFNOT EXISTSsamp_db;

添加IF NOT EXISTS可防止发生错误。

使用DROP DATABASE语句删除数据库。例如:


              
DROPDATABASE samp_db;

创建、查看和删除表

使用创建TABLE语句创建表。语法如下:


              
创建 TABLEtable_name column_name data_typeconstraint;

例如,要创建一个名为person的表,包括编号、名字、生日等字段,可使用以下语句:


              
创建 TABLEperson ( idINT(11), nameVARCHAR(255), birthdayDATE);

使用SHOW CREATE语句查看建表语句,即 DDL。例如:


              
SHOW 创建 TABLE人;

使用DROP TABLE语句删除表。例如:


              
DROP TABLE人;

创建、查看和删除索引

索引通常用于加速索引列上的查询。对于值不唯一的列,可使用创建INDEXALTER TABLE语句创建普通索引。例如:


              
创建INDEX person_idONperson (id);

或者:


              
ALTER TABLEpersonADDINDEX person_id (id);

对于值唯一的列,可以创建唯一索引。例如:


              
创建 UNIQUEINDEX person_unique_idONperson (id);

或者:


              
ALTER TABLEpersonADD UNIQUEperson_unique_id (id);

使用SHOW INDEX语句查看表内所有索引:


              
SHOWINDEXFROM人;

使用ALTER TABLEDROP INDEX语句来删除索引。与创建INDEX语句类似,DROP INDEX也可以嵌入ALTER TABLE语句。例如:


              
DROPINDEX person_idON人;

              
ALTER TABLEpersonDROPINDEX person_unique_id;

注意:DDL 操作不是事务,在执行 DDL 时,不需要对应 COMMIT 语句。

常用的 DML 功能是对表记录的新增、修改和删除,对应的命令分别是 INSERT、UPDATE 和 DELETE。

记录的增删改

使用INSERT语句向表内插入表记录。例如:


              
INSERT INTOpersonVALUES(1,'tom','20170912');

使用INSERT语句向表内插入包含部分字段数据的表记录。例如:


              
INSERT INTO人(id、name)VALUES('2','bob');

使用UPDATE语句向表内修改表记录的部分字段数据。例如:


              
UPDATEpersonSETbirthday= '20180808' WHEREid= 2;

使用DELETE语句向表内删除部分表记录。例如:


              
DELETE FROMpersonWHEREid= 2;

注意:UPDATE 和 DELETE 操作如果不带 WHERE 过滤条件是对全表进行操作。

DQL 数据查询语言是从一个表或多个表中检索出想要的数据行,通常是业务开发的核心内容。

查询数据

使用SELECT语句检索表内数据。例如:


              
SELECT * FROM人;

在 SELECT 后面加上要查询的列名。例如:


              
SELECTnameFROM人;

              
+ ------+ |name| + ------+ |tom| + ------+ 1 rows in set(0.00sec)

使用 WHERE 子句,对所有记录进行是否符合条件的筛选后再返回。例如:


              
SELECT * FROMpersonWHEREid< 5;

常用的 DCL 功能是创建或删除用户,和对用户权限的管理。

创建、授权和删除用户

使用创建USER语句创建一个用户tiuser,密码为123456


              
创建 USER 'tiuser'@'localhost'IDENTIFIEDBY '123456';

授权用户tiuser可检索数据库samp_db内的表:


              
GRANT SELECT ONsamp_db.* TO 'tiuser'@'localhost';

查询用户tiuser的权限:


              
SHOWGRANTSfortiuser@localhost;

删除用户tiuser


              
DROP USER 'tiuser'@'localhost';
下载 PDF 文档反馈 社区交流
文档内容是否有帮助?
产品
TiDB
TiDB Cloud
©2023PingCAP. All Rights Reserved.