1、数据查询关键字
SELECT:用于从数据库中查询数据。SELECT name, age FROM users;
,该语句从users
表中选择name
和age
列。
WHERE:指定查询的条件。SELECT * FROM users WHERE age > 18;
,该语句仅返回年龄大于18的用户记录。
ORDER BY:对查询结果进行排序。SELECT * FROM users ORDER BY age DESC;
,该语句按年龄降序排列用户记录。
GROUP BY:将结果集按一列或多列进行分组。SELECT department, COUNT(*) FROM employees GROUP BY department;
,该语句按部门统计员工数量。
HAVING:用于对分组后的结果进行过滤。SELECT department, COUNT(*) FROM employees GROUP BY department HAVING COUNT(*) > 10;
,该语句仅返回员工数量大于10的部门。
2、数据操作关键字
INSERT INTO:向表中插入新数据。INSERT INTO users (name, age) VALUES ('Alice', 30);
,该语句向users
表插入一条新的用户记录。
UPDATE:更新表中的现有数据。UPDATE users SET age = 31 WHERE name = 'Alice';
,该语句将名为Alice的用户的年龄更新为31。
DELETE FROM:删除表中的数据。DELETE FROM users WHERE age < 18;
,该语句删除所有年龄小于18的用户记录。
3、数据定义关键字
CREATE TABLE:创建新表。CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50), age INT);
,该语句创建一个名为users
的新表,并定义其结构。
ALTER TABLE:修改现有表的结构。ALTER TABLE users ADD email VARCHAR(100);
,该语句在users
表中添加一个新的电子邮件列。
DROP TABLE:删除表及其数据。DROP TABLE users;
,该语句删除整个users
表。
4、数据约束关键字
PRIMARY KEY:定义主键,确保唯一性。CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50));
,该语句在users
表中定义id
为主键。
FOREIGN KEY:定义外键,建立表间的关系。CREATE TABLE orders (id INT NOT NULL, student_id INT NOT NULL, order_date DATE NOT NULL, CONSTRAINT fk_student_id FOREIGN KEY (student_id) REFERENCES students(id));
,该语句在orders
表中定义一个外键,引用students
表的id
列。
UNIQUE:确保列中的值唯一。CREATE TABLE users (email VARCHAR(100) UNIQUE);
,该语句确保users
表中的email
列的值是唯一的。
NOT NULL:确保列中的值不能为空。CREATE TABLE users (name VARCHAR(50) NOT NULL);
,该语句确保users
表中的name
列不能为空。
5、数据库管理关键字
USE:选择要使用的数据库。USE my_database;
,该语句选择名为my_database
的数据库。
SHOW TABLES:显示当前数据库中的所有表。SHOW TABLES;
,该语句列出当前数据库中的所有表。
DESCRIBE:显示表的结构。DESCRIBE users;
,该语句显示users
表的结构。
DROP DATABASE:删除数据库及其所有对象。DROP DATABASE my_database;
,该语句删除名为my_database
的数据库及其所有内容。
6、事务控制关键字
BEGIN/START TRANSACTION:显式开启一个事务。START TRANSACTION;
,该语句开始一个新的事务。
COMMIT:提交当前事务,使事务中的所有操作生效。COMMIT;
,该语句提交当前事务。
ROLLBACK:回滚当前事务,撤销事务中的所有操作。ROLLBACK;
,该语句撤销当前事务。
SAVEPOINT:在事务中设置保存点,以便部分回滚。SAVEPOINT sp1;
,该语句设置一个名为sp1
的保存点。
RELEASE SAVEPOINT:删除指定的保存点。RELEASE SAVEPOINT sp1;
,该语句删除名为sp1
的保存点。
7、其他常用关键字
ADD:向现有表添加一列或多列。ALTER TABLE employees ADD birth_date DATE;
,该语句在employees
表中添加一个名为birth_date
的新列。
MODIFY:修改表的结构,例如更改列名、更改列的数据类型等。ALTER TABLE employees MODIFY salary DECIMAL(12, 2);
,该语句将employees
表中的salary
列的数据类型修改为DECIMAL(12, 2)
。
EXISTS:用于检查一个子查询是否有结果集。SELECT * FROM employees WHERE EXISTS (SELECT 1 FROM orders WHERE orders.employee_id = employees.id);
,该语句检查是否存在与员工相关的订单。
FAQs
Q1: 如何在MySQL中使用关键字来创建索引?
A1: 在MySQL中,可以使用“KEY”关键字来创建索引,以下SQL语句为“students”表中的“name”列创建了一个名为“idx_name”的索引:
CREATE TABLE students ( id INT NOT NULL, name VARCHAR(50) NOT NULL, PRIMARY KEY (id), KEY idx_name (name) );
当在查询语句中使用“idx_name”时,MySQL会从这个索引中快速查找数据,而不是全表扫描,从而提高了查询效率。
Q2: 如何在MySQL中使用关键字来定义外键?
A2: 在MySQL中,可以使用“FOREIGN KEY”关键字来定义外键,以下SQL语句为“orders”表中的“student_id”列定义了一个外键,参考了“students”表的“id”列:
CREATE TABLE orders ( id INT NOT NULL, student_id INT NOT NULL, order_date DATE NOT NULL, PRIMARY KEY (id), CONSTRAINT fk_student_id FOREIGN KEY (student_id) REFERENCES students(id) );
这样,在“orders”表中插入数据时,MySQL会先检查“student_id”列的值是否在“students”表的“id”列中存在,如果不存在,就无法插入,从而保证了数据的完整性和一致性。
小编有话说
熟练掌握MySQL数据库的关键字对于数据库操作至关重要,这些关键字不仅帮助开发者高效地管理和操作数据库,还能提高编程和开发的效率,通过本文的介绍,希望大家能够更好地理解和应用这些关键字,提升自己的数据库技能,如果你有任何疑问或需要进一步的帮助,请随时联系我。