欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > 数据库的增删改查操作语句及一些常用的进阶语句

数据库的增删改查操作语句及一些常用的进阶语句

2024/10/24 23:21:18 来源:https://blog.csdn.net/qq_43158726/article/details/139632054  浏览:    关键词:数据库的增删改查操作语句及一些常用的进阶语句

在关系数据库管理系统(RDBMS)中,增删改查(CRUD)操作是最基本的数据库操作。以下是这些操作的详细介绍以及其他常用的数据库操作语句。

增(Create/Insert)

1. 创建数据库

创建一个新的数据库。

CREATE DATABASE database_name;

2. 创建表

在指定的数据库中创建一个新表。

CREATE TABLE table_name (column1 data_type constraints,column2 data_type constraints,...
);

例如:

CREATE TABLE employees (id INT AUTO_INCREMENT PRIMARY KEY,first_name VARCHAR(50) NOT NULL,last_name VARCHAR(50) NOT NULL,email VARCHAR(100) UNIQUE,hire_date DATE,salary DECIMAL(10, 2)
);

3. 插入数据

向表中插入新记录。

INSERT INTO table_name (column1, column2, ...)
VALUES (value1, value2, ...);

例如:

INSERT INTO employees (first_name, last_name, email, hire_date, salary)
VALUES ('John', 'Doe', 'john.doe@example.com', '2023-01-15', 50000.00);

删(Delete)

1. 删除记录

从表中删除一条或多条记录。

DELETE FROM table_name WHERE condition;

例如:

DELETE FROM employees WHERE id = 10;

2. 删除表

从数据库中删除表及其所有数据。

DROP TABLE table_name;

3. 删除数据库

删除整个数据库及其所有包含的表。

DROP DATABASE database_name;

改(Update)

1. 更新记录

更新表中的现有记录。

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

例如:

UPDATE employees
SET salary = salary * 1.1
WHERE hire_date < '2022-01-01';

查(Read/Retrieve/Select)

1. 简单查询

从表中选择数据。

SELECT column1, column2, ...
FROM table_name;

例如:

SELECT first_name, last_name, salary
FROM employees;

2. 带条件的查询

查询包含特定条件的数据。

SELECT column1, column2, ...
FROM table_name
WHERE condition;

例如:

SELECT first_name, last_name
FROM employees
WHERE salary > 50000;

3. 多条件查询

使用 AND 和 OR 进行复杂的条件查询。

SELECT column1, column2, ...
FROM table_name
WHERE condition1 AND condition2;

SELECT column1, column2, ...
FROM table_name
WHERE condition1 OR condition2;

例如:

SELECT first_name, last_name
FROM employees
WHERE salary > 50000 AND hire_date < '2023-01-01';

4. 排序

按照指定的列排序结果集。

SELECT column1, column2, ...
FROM table_name
ORDER BY column1 [ASC|DESC], column2 [ASC|DESC];

例如:

SELECT first_name, last_name, salary
FROM employees
ORDER BY salary DESC;

5. 分组

按照指定的列对结果集进行分组,并可使用聚合函数。

SELECT column1, aggregate_function(column2)
FROM table_name
GROUP BY column1;

例如:

SELECT department_id, COUNT(*)
FROM employees
GROUP BY department_id;

6. 分页

限制查询结果的数量,用于分页显示。

SELECT column1, column2, ...
FROM table_name
LIMIT offset, count;

例如:

SELECT first_name, last_name
FROM employees
LIMIT 0, 10; -- 获取前10条记录

其他操作

1. 修改表

修改表结构,如添加、修改或删除列。

-- 添加列
ALTER TABLE table_name ADD column_name data_type;-- 修改列
ALTER TABLE table_name MODIFY column_name new_data_type;-- 删除列
ALTER TABLE table_name DROP COLUMN column_name;

例如:

ALTER TABLE employees ADD birthdate DATE;

2. 创建索引

创建索引以加速查询。

CREATE INDEX index_name ON table_name (column_name);

例如:

CREATE INDEX idx_last_name ON employees (last_name);

3. 创建视图

创建一个视图。

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

例如:

CREATE VIEW high_salary_employees AS
SELECT first_name, last_name, salary
FROM employees
WHERE salary > 70000;

4. 创建存储过程

创建存储过程用于封装一组SQL语句。

DELIMITER //CREATE PROCEDURE procedure_name (parameters)
BEGIN-- SQL语句
END //DELIMITER ;

例如:

DELIMITER //CREATE PROCEDURE increase_salary (IN emp_id INT, IN increment DECIMAL(10, 2))
BEGINUPDATE employeesSET salary = salary + incrementWHERE id = emp_id;
END //DELIMITER ;

5. 执行存储过程

执行存储过程。

CALL procedure_name(parameters);

例如:

CALL increase_salary(1, 1000.00);

6. 创建触发器

创建触发器在特定事件发生时执行。

CREATE TRIGGER trigger_name
BEFORE/AFTER INSERT/UPDATE/DELETE
ON table_name
FOR EACH ROW
BEGIN-- SQL语句
END;

例如:

CREATE TRIGGER before_employee_insert
BEFORE INSERT ON employees
FOR EACH ROW
BEGINSET NEW.hire_date = IFNULL(NEW.hire_date, CURDATE());
END;

这些操作涵盖了数据库管理和数据操作的基本语句。了解和熟练使用这些语句,可以帮助你有效地管理数据库和处理数据。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com