常用SQL语句操作数据库

在SQL中,主要的操作可以被分为以下几种:

复制代码
	DDL(Data Definition Language): 用于定义、更改、删除数据库和数据库对象。
	DML(Data Manipulation Language): 用于增加、修改、删除和查询数据库记录。
	DCL(Data Control Language): 用于定义对数据库的访问权限和安全级别,及创建用户。

以下是一些基本的SQL语句例子:

创建数据库: CREATE DATABASE dbname;

删除数据库: DROP DATABASE dbname;

使用数据库: USE dbname;

查看数据库: SHOW databases;

创建表格: CREATE TABLE table_name (column1 datatype, column2 datatype);

删除表格: DROP TABLE table_name;

为现有表添加列: ALTER TABLE table_name ADD column datatype;

删除现有表中的列: ALTER TABLE table_name DROP COLUMN column_name;

重命名表: ALTER TABLE table_name RENAME TO new_table_name;

向表中插入数据: INSERT INTO table_name (column1, column2) VALUES (value1, value2);

从表中查询数据: SELECT column1, column2 FROM table_name;

从表中查询所有数据: SELECT * FROM table_name;

更新表中的数据: UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition;

从表中删除数据: DELETE FROM table_name WHERE condition;

查询表中唯一不同的值: SELECT DISTINCT column_name FROM table_name;

计数表中的记录: SELECT COUNT(column_name) FROM table_name;

对查询结果进行排序: SELECT column1, column2 FROM table_name ORDER BY column_name ASC|DESC;

设置查询条件: SELECT column1, column2 FROM table_name WHERE condition;

对查询结果进行分组: SELECT column1, COUNT(column2) FROM table_name GROUP BY column_name;

将多个条件组合在一起: SELECT column1, column2 FROM table_name WHERE condition1 AND|OR condition2;

对查询的结果进行限制: SELECT column_name(s) FROM table_name LIMIT number;

联接多个表:SELECT ORDER_ID, VENDOR_CODE, ORDER_AMOUNT FROM ORDERS INNER JOIN VENDORS ON ORDERS.VENDOR_ID = VENDORS.VENDOR_ID;

查询表的结构:DESC table_name;

更改表的列数据类型:ALTER TABLE table_name MODIFY COLUMN column_name column_type;

对多表查询的结果进行排序: SELECT Orders.OrderID, Customers.CustomerName, Orders.OrderDate FROM Orders, Customers WHERE Orders.CustomerID = Customers.CustomerID ORDER BY Orders.OrderDate;

创建索引:CREATE INDEX index_name ON table_name (column1, column2, ...);

删除索引: DROP INDEX index_name;

创建视图: CREATE VIEW view_name AS SELECT column_name(s) FROM table_name WHERE condition;

删除视图: DROP VIEW view_name;

删除表中的所有行: TRUNCATE TABLE table_name;

创建存储过程: CREATE PROCEDURE procedure_name AS sql_statement GO;

删除存储过程: DROP PROCEDURE procedure_name;

调用存储过程: EXEC procedure_name;

创建触发器: CREATE TRIGGER trigger_name trigger_time trigger_event ON table_name FOR EACH ROW BEGIN sql to be executed; END;

删除触发器: DROP TRIGGER table_name.trigger_name;

创建临时表: CREATE TEMPORARY TABLE table_name (column_name column_type);

复制表(结构+数据): CREATE TABLE new_table AS SELECT * FROM existing_table;

复制表(只复制结构): CREATE TABLE new_table AS SELECT * FROM existing_table WHERE 1=0;

取值非空的第一条记录: SELECT column_name(s) FROM table_name WHERE column_name IS NOT NULL;

查询某列的最大值:SELECT MAX(column_name) FROM table_name;

查询某列的最小值:SELECT MIN(column_name) FROM table_name;

计算某列的总和:SELECT SUM(column_name) FROM table_name;

计算某列的平均值:SELECT AVG(column_name) FROM table_name;

更改默认排序规则:ALTER DATABASE dbname COLLATE collation_name;

更改表的默认排序规则:ALTER TABLE table_name COLLATE collation_name;

更改列的默认排序规则:ALTER TABLE table_name ALTER COLUMN column_name COLLATE collation_name;

创建函数: CREATE FUNCTION function_name ([param[, ...]) RETURNS return_datatype language_name AS function_body;

删除函数: DROP FUNCTION function_name;

使用IF ELSE语句: SELECT IF(column_name = condition, 'True', 'False') AS AliasName FROM table_name;

使用CASE语句: SELECT column_name, CASE WHEN condition1 THEN result1 WHEN condition2 THEN result2 ELSE result3 END AS AliasName FROM table_name;

相关推荐
雷工笔记1 小时前
SQL语句解析:DESC LIMIT 1
数据库·sql
墨北小七1 小时前
小说大模型的分布式训练——数据并行架构设计与实现
分布式
lzhdim2 小时前
SQL 入门 10:SQL 内置函数:数值、字符串与时间处理
前端·数据库·sql
qq_297574672 小时前
【Kafka系列·进阶第一篇】生产可靠性实战:死信队列+幂等性+集群扩容+灾备切换
分布式·kafka
隐于花海,等待花开3 小时前
为什么要避免 SELECT *
sql
无忧智库3 小时前
企业数字化的“底层逻辑”:深度解构4A架构中的数据基石(PPT)
分布式·微服务·架构
请为小H留灯5 小时前
Kafka详解及实战案例
分布式·kafka·linq·消费
想你依然心痛5 小时前
HarmonyOS 5.0智慧交通开发实战:构建分布式车载智能座舱与手机无缝互联系统
分布式·智能手机·harmonyos·智慧交通·智能座舱
小白学大数据6 小时前
分布式爬虫核心技术详解与工程实践
开发语言·分布式·爬虫·python
夜晚打字声6 小时前
12(十二)Jmeter分布式配置
分布式·jmeter