sql 备忘单
本博客全面指导最重要的sql命令和操作。它涵盖了基本查询、连接、子查询、索引和更高级的概念。
目录
- sql 基础知识
- 数据定义语言(ddl)
- 数据操作语言(dml)
- 数据查询语言(dql)
- 数据控制语言(dcl)
- 加入
- 子查询
- 索引
- 聚合函数
- 分组和排序
- 交易
- 高级 sql
- 最佳实践
sql 基础知识
sql 查询的结构
select column1, column2 from table_name where condition order by column limit n;登录后复制
在 sql 中注释
- 单行评论: -- 这是一条评论
- 多行评论:
/* this is a multi-line comment */登录后复制
数据定义语言(ddl)
创建表
create table table_name ( column1 datatype [constraints], column2 datatype [constraints], ... );登录后复制
示例:
create table employees ( id int primary key, name varchar(100), age int, hire_date date );登录后复制
修改表格
添加列
alter table table_name add column_name datatype;登录后复制
删除一列
alter table table_name drop column column_name;登录后复制
修改列
alter table table_name modify column column_name datatype;登录后复制
重命名表
alter table old_table_name rename to new_table_name;登录后复制
删除一个表
drop table table_name;登录后复制
创建索引
create index index_name on table_name (column_name);登录后复制
删除索引
drop index index_name;登录后复制 登录后复制
数据操作语言 (dml)
将数据插入表中
insert into table_name (column1, column2, ...) values (value1, value2, ...);登录后复制
示例:
insert into employees (id, name, age, hire_date) values (1, 'john doe', 30, '2022-01-01');登录后复制
更新表中的数据
update table_name set column1 = value1, column2 = value2, ... where condition;登录后复制
示例:
update employees set age = 31 where id = 1;登录后复制
从表中删除数据
delete from table_name where condition;登录后复制
示例:
delete from employees where id = 1;登录后复制
数据查询语言 (dql)
从表中选择数据
select column1, column2, ... from table_name where condition order by column limit n;登录后复制
示例:
select * from employees; select name, age from employees where age > 30;登录后复制
通配符
- *:选择所有列
- %:零个或多个字符的通配符(在 like 子句中)
- _:仅代表一个字符的通配符(在 like 子句中)
示例:
select * from employees where name like 'j%';登录后复制
数据控制语言(dcl)
授予权限
grant permission on object to user;登录后复制
示例:
grant select, insert on employees to 'user1';登录后复制
撤销权限
revoke permission on object from user;登录后复制
示例:
revoke select on employees from 'user1';登录后复制
加入
内连接
当两个表中存在匹配项时返回行。
select columns from table1 inner join table2 on table1.column = table2.column;登录后复制
左连接(或左外连接)
返回左表中的所有行以及右表中的匹配行。如果不匹配,右表中的列将显示 null 值。
select columns from table1 left join table2 on table1.column = table2.column;登录后复制
右连接(或右外连接)
返回右表中的所有行以及左表中的匹配行。如果不匹配,左表中的列将显示 null 值。
select columns from table1 right join table2 on table1.column = table2.column;登录后复制
全外连接
当其中一个表中有匹配项时返回行。
select columns from table1 full outer join table2 on table1.column = table2.column;登录后复制
子查询
select 中的子查询
select column1, (select column2 from table2 where condition) as alias from table1;登录后复制
where 中的子查询
select column1 from table1 where column2 in (select column2 from table2 where condition);登录后复制
from 中的子查询
select alias.column1 from (select column1 from table2 where condition) as alias;登录后复制
索引
创建索引
create index index_name on table_name (column1, column2);登录后复制
删除索引
drop index index_name;登录后复制 登录后复制
唯一索引
确保一列(或一组列)中的所有值都是唯一的。
create unique index index_name on table_name (column_name);登录后复制
聚合函数
数数
计算符合特定条件的行数。
select count(*) from table_name where condition;登录后复制
和
返回列中值的总和。
select sum(column_name) from table_name;登录后复制
平均电压
返回列中值的平均值。
select avg(column_name) from table_name;登录后复制
最小值和最大值
返回列中的最小值和最大值。
select min(column_name), max(column_name) from table_name;登录后复制
分组和排序
分组依据
将具有相同值的行分组为汇总行。
select column1, count(*) from table_name group by column1;登录后复制
拥有
应用 group by 后过滤组。
select column1, count(*) from table_name group by column1 having count(*) > 5;登录后复制
订购依据
按升序或降序对结果集进行排序。
select column1, column2 from table_name order by column1 desc;登录后复制
交易
开始交易
begin transaction;登录后复制
进行交易
commit;登录后复制
回滚事务
rollback;登录后复制
高级sql
案例当
查询中的条件逻辑。
select column1, case when condition then 'result 1' when condition then 'result 2' else 'default' end as alias from table_name;登录后复制
联合和联合全部
- union:合并两个或多个查询的结果集(删除重复项)。
- union all:合并结果集(保留重复项)。
select column from table1 union select column from table2; select column from table1 union all select column from table2;登录后复制
最佳实践
- 尽可能使用 join 而不是子查询以获得更好的性能。
- 对经常搜索的列建立索引以加快查询速度。
- 避免 select * 并仅指定您需要的列。
- 对大型结果集使用 limit 限制返回的行数。
- 标准化您的数据以避免冗余并提高一致性。
- 使用where子句而不是在聚合之前过滤数据。
- 测试查询性能,特别是对于大型数据集。
- 使用事务来保证数据的一致性,尤其是涉及多个dml语句的操作。
结论
此 sql 备忘单涵盖了使用关系数据库所需的所有基本 sql 命令和技术。无论您是查询、插入、更新还是连接数据,本指南都将帮助您更有效地使用 sql。
登录后复制
以上就是SQL 快速参考:简化数据库管理的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » SQL 快速参考:简化数据库管理
发表评论 取消回复