常用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;

相关推荐
月落星还在2 小时前
ZooKeeper的五大核心作用及其在分布式系统中的关键价值
分布式·zookeeper·云原生
幼儿园扛把子\11 小时前
RabbitMQ入门:从安装到高级消息模式
分布式·rabbitmq·java-rabbitmq
划水哥~11 小时前
SQL99 多表查询
数据库·sql
王ASC11 小时前
kettle的转换中sql不按设计顺序执行原因分析与解决办法
数据库·sql
人类群星闪耀时11 小时前
数据分析入门:从数据探索到洞察真相
大数据·hadoop·sql
猿小喵12 小时前
MySQL异常SQL排查
数据库·sql·mysql
天才测试猿15 小时前
Pytest自动化测试框架pytest-xdist分布式测试插件
自动化测试·软件测试·分布式·python·测试工具·测试用例·pytest
就改了17 小时前
mysql进阶——数据类型一篇详解
数据库·sql
元气满满的热码式17 小时前
使用Fluent-bit将容器标准输入和输出的日志发送到Kafka
分布式·云原生·kafka·kubernetes
宋发元17 小时前
从网络通信探究分布式通信的原理
分布式