SQL 语句
原创2023年12月19日
为了操作 MySQL 数据库,需要使用名为 SQL 的语言与它进行交互。
SQL
结构化查询语言(Structured Query Language,SQL)是一种用于管理和操作关系型数据库的标准化语言。SQL
提供了一种简洁、灵活和可扩展的方式来访问和处理数据库中的数据。MySQL
的 SQL
语句分为以下三类:
数据操作语言(DML):允许用户使用查询语句
SELECT
检索数据、插入新数据INSERT
、更新数据UPDATE
和删除数据DELETE
。这些操作可以根据指定的条件对数据库中的数据进行选择性操作。数据定义语言(DDL):定义数据库结构的语句,如创建表
CREATE TABLE
、修改表结构ALTER TABLE
和删除表DROP TABLE
。用于创建、修改和删除数据库对象,如表、索引、视图等。数据控制语言(DCL):数据访问和安全性控制。这包括授权用户对数据库对象的访问权限、定义用户角色和权限、以及在数据库中实施数据完整性和安全性约束。
下面使用 SQL
语句简单地创建一个数据库 mydb
,在其中的表 user
中插入一条记录。
MySQL
的关键字不区分大小写,比如关键字 CREATE
和 create
的作用是完全相同的。
CREATE DATABASE mydb;
USE mydb;
CREATE TABLE user (name char(20), age int, birthday date);
INSERT INTO user (name, age, birthday) VALUES ('akashi', 20, '2004-01-01');
SELECT * FROM user;
需要注意的是,这里输入的 SQL
语句需要以 ;
、\g
或 \G
结尾,mysql
命令的交互界面支持换行输入。
mysql> CREATE DATABASE mydb;
Query OK, 1 row affected (0.00 sec)
mysql> USE mydb;
Database changed
mysql> CREATE TABLE user (
-> name char(20),
-> age int,
-> birthday date
-> );
Query OK, 0 rows affected (0.02 sec)
mysql> SHOW TABLES;
+----------------+
| Tables_in_mydb |
+----------------+
| user |
+----------------+
1 row in set (0.00 sec)
mysql> INSERT INTO user (name, age, birthday) VALUES ('akashi', 20, '2004-01-01');
Query OK, 1 row affected (0.01 sec)
mysql> SELECT * FROM user;
+--------+------+------------+
| name | age | birthday |
+--------+------+------------+
| akashi | 20 | 2004-01-01 |
+--------+------+------------+
1 row in set (0.00 sec)
数据库和数据表是 MySQL
中的重要概念。它们的关系是:一个 MySQL
服务器可以包含多个数据库,一个数据库可以包含多个数据表。