百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

数据库中sql语句大全

ztj100 2024-12-10 22:17 38 浏览 0 评论

结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;

sql 语句就是对数据库进行操作的一种语言。

数据库操作

1、查看所有数据库

show databases

2、查看当前使用的数据库

select databases()

3、创建数据库

CREATE DATABASE database-name

4、删除数据库

drop database dbname

5、创建新表

create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)

6、删除新表

drop table tabname

7、增加一个列

Alter table tabname add column col type

8、添加主键

Alter table tabname add primary key(col)

9、删除主键

Alter table tabname drop primary key(col)

10、创建索引

create [unique] index idxname on tabname(col….)

11、删除索引

drop index idxname

12、创建视图

create view viewname as select statement

13、删除视图

drop view viewname

常见语句

更新:update table1 set field1=value1 where 范围

查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)

排序:select * from table1 order by field1,field2 [desc]

求和:select sum(field1) as sumvalue from table1

平均:select avg(field1) as avgvalue from table1

最大:select max(field1) as maxvalue from table1

最小:select min(field1) as minvalue from table1[separator]

条件语句查询

where后面支持多种运算符,进行条件的处理
比较运算符
逻辑运算符
模糊查询
范围查询
空判断

比较运算符

等于: =
大于: >
大于等于: >=
小于: <
小于等于: <=
不等于: != 或 <>

例1:查询编号大于3的学生

select * from students where id > 3;

 

例2:查询姓名不是“黄蓉”的学生

select * from students where name != '黄蓉';

 

例3:查询没被删除的学生

select * from students where is_delete=0;

 

逻辑运算符

and
or
not

例4:查询编号大于3的女同学

select * from students where id > 3 and gender=0;

 

例5:查询编号小于4或没被删除的学生

select * from students where id < 4 or is_delete=0;

 

模糊查询

like
%表示任意多个任意字符
_表示一个任意字符

例6:查询姓黄的学生例

select * from students where name like '黄%';

 

例7:查询姓黄或叫靖的学生

select * from students where name like '黄%' or name like '%靖';

范围查询

范围查询分为连续范围查询和非连续范围查询

  1. in表示在一个非连续的范围内
    例8:查询编号是1或3或8的学生in表示在一个非连续的范围内
select * from students where id in(1,3,8);

 

2.between … and …表示在一个连续的范围内
例9:查询编号为3至8的学生

select * from students where id between 3 and 8;

空判断

判断为空
例10:查询没有填写身高的学生

select * from students where height is null;

 

注意: 1. null与’'是不同的 2. is null
判非空is not null
例11:查询填写了身高的学生

select * from students where height is not null;

优先级优先级由高到低的顺序为:小括号,not,比较运算符,逻辑运算符and比or先运算,如果同时出现并希望先算or,需要结合()使用

排序

排序查询语法:

select * from 表名 order by 列1 asc|desc [,列2 asc|desc,...]

 

语法说明:
将行数据按照列1进行排序,如果某些行 列1 的值相同时,则按照 列2 排序,以此类推
asc从小到大排列,即升序
desc从大到小排序,即降序
默认按照列值从小到大排列(即asc关键字)

例1:查询未删除男生信息,按学号降序

select * from students where gender=1 and is_delete=0 order by id desc;

 

例2:查询未删除学生信息,按名称升序

select * from students where is_delete=0 order by name;

 

例3:显示所有的学生信息,先按照年龄从大–>小排序,当年龄相同时 按照身高从高–>矮排序

select * from students  order by age desc,height desc;

 

分页

select * from 表名 limit start=0,count

 

说明
从start开始,获取count条数据
start默认值为0
也就是当用户需要获取数据的前n条的时候可以直接写上 xxx limit n;

例1:查询前3行男生信息

select * from students where gender=1 limit 0,3;

 

关于分页的一个有趣的推导公式

已知:每页显示m条数据,当前显示第n页

求总页数:此段逻辑后面会在python项目中实现

查询总条数p1
使用p1除以m得到p2
如果整除则p2为总数页
如果不整除则p2+1为总页数
获取第n页的数据的SQL语句求解思路

第n页前有n-1页
所在第n页前已经显示的数据的总量是(n-1)*m
由于数据的下标从0开始 所以第n页前所有的网页的下标是0,1,…,(n-1)*m-1
所以第n页的数据起始下标是(n-1)*m
获取第n页数据的SQL语句

select * from students where is_delete=0 limit (n-1)*m,m

 

注意:在sql语句中limit后不可以直接加公式

聚合函数

总数

count(*) 表示计算总行数,括号中写星与列名,结果是相同的
例1:查询学生总数

select count(*) from students;

 

最大值

max(列) 表示求此列的最大值

例2:查询女生的编号最大值

select max(id) from students where gender=2;

 

最小值

min(列) 表示求此列的最小值

例3:查询未删除的学生最小编号

select min(id) from students where is_delete=0;

 

求和

sum(列) 表示求此列的和

例4:查询男生的总年龄

select sum(age) from students where gender=1;

 

平均年龄

select sum(age)/count(*) from students where gender=1;

 

平均值

avg(列) 表示求此列的平均值

例5:查询未删除女生的编号平均值

select avg(id) from students where is_delete=0 and gender=2;

 

分组

group by

group by + group_concat()

group_concat(字段名)根据分组结果,使用group_concat()来放置每一个分组中某字段的集合



group by + 聚合函数

通过group_concat()的启发,我们既然可以统计出每个分组的某字段的值的集合,那么我们也可以通过集合函数来对这个值的集合做一些操作



group by + having

having 条件表达式:用来过滤分组结果
having作用和where类似,但having只能用于group by 而where是用来过滤表数据

group by + with rollup

with rollup的作用是:在最后新增一行,来记录当前表中该字段对应的操作结果,一般是汇总结果。


连接查询语法

对于外连接 outer关键字可以省略

select * from 表1 inner或left或right join 表2 on 表1.列 运算符 表2.列

 

例1:使用内连接查询班级表与学生表

select * from students inner join classes on students.cls_id = classes.id;

 

例2:使用左连接查询班级表与学生表
此处使用了as为表起别名,目的是编写简单

select * from students as s left join classes as c on s.cls_id = c.id;

 

例3:使用右连接查询班级表与学生表

select * from students as s right join classes as c on s.cls_id = c.id;

 

例4:查询学生姓名及班级名称

select s.name,c.name from students as s inner join classes as c on s.cls_id = c.id;

 

子查询

在一个 select 语句中,嵌入了另外一个 select 语句, 那么被嵌入的 select 语句称之为子查询语句,外部那个select语句则称为主查询.
主查询和子查询的关系
子查询是嵌入到主查询中
子查询是辅助主查询的,要么充当条件,要么充当数据源
子查询是可以独立存在的语句,是一条完整的 select 语句

标量子查询

查询班级学生平均年龄
查询大于平均年龄的学生
查询班级学生的平均身高

select * from students where age > (select avg(age) from students);

 

列级子查询

查询还有学生在班的所有班级名字
找出学生表中所有的班级 id
找出班级表中对应的名字

select name from classes where id in (select cls_id from students);

 

行级子查询

需求: 查找班级年龄最大,身高最高的学生
行元素: 将多个字段合成一个行元素,在行级子查询中会使用到行元素

select * from students where (height,age) = (select max(height),max(age) from students);

 

相关推荐

Docker安全开放远程访问连接权限(docker 远程授权访问)

1、Docker完全开放远程访问Docker服务完全开放对外访问权限操作如下:#开启端口命令(--permanent永久生效,没有此参数重启后失效)firewall-cmd--zone=pu...

SpringCloud系列——4OpenFeign简介及应用

学习目标什么是OpenFeign以及它的作用RPC到底怎么理解OpenFeign的应用第1章OpenFeign简介在前面的内容中,我们分析了基于RestTemplate实现http远程通信的方法。并...

Spring Boot集成qwen:0.5b实现对话功能

1.什么是qwen:0.5b?模型介绍:Qwen1.5是阿里云推出的一系列大型语言模型。Qwen是阿里云推出的一系列基于Transformer的大型语言模型,在大量数据(包括网页文本、书籍、代码等)...

JDK从8升级到21的问题集(jdk8升级到11)

一、背景与挑战1.升级动因oOracle长期支持策略o现代特性需求:协程、模式匹配、ZGC等o安全性与性能的需求oAI新技术引入的版本要求...

大白话详解Spring Cloud服务降级与熔断

1.Hystrix断路器概述1.1分布式系统面临的问题复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免地失败。这就造成有可能会发生...

面试突击43:lock、tryLock、lockInterruptibly有什么区别?

在Lock接口中,获取锁的方法有4个:lock()、tryLock()、tryLock(long,TimeUnit)、lockInterruptibly(),为什么需要这么多方法?这些方法都有...

了解网络编程 TCP/IP 协议与UDP 协议

因为iP地址比较难记忆,很多情况下可以使用域名代替iP地址。1.TCP/IP协议与UDP协议通过IP地址与端口号确定计算机在网络中的位置后,接下来考虑通讯的问题:因为不同计算机的软硬件平台...

Semaphore与Exchanger的区别(semaphore和signal)

Semaphore和Exchanger是Java并发编程中两个常用的同步工具类,它们都可以用于协调多个线程之间的执行顺序和状态,但它们的作用和使用方式有所不同:Semaphore类表示一个...

Java教程:什么是分布式任务调度?怎样实现任务调度?

通常任务调度的程序是集成在应用中的,比如:优惠卷服务中包括了定时发放优惠卷的的调度程序,结算服务中包括了定期生成报表的任务调度程序...

java多线程—Runnable、Thread、Callable区别

多线程编程优点:进程之间不能共享内存,但线程之间共享内存非常容易。系统创建线程所分配的资源相对创建进程而言,代价非常小。Java中实现多线程有3种方法:继承Thread类实现Runnable...

工厂模式详解(工厂模式是啥意思)

工厂模式详解简单工厂简单工厂模式(SimpleFactoryPattern)是指由一个工厂对象决定创建出哪一种产品类的实例。简单工厂适用于工厂类负责创建的对象较少的场景,且客户端只需要传入工厂类的...

我们程序员眼中的母亲节(你眼中的程序员是什么样子的?程序员的薪酬如何?)

导语:对于我们成人来说,尤其是漂泊在外的程序员,陪伴父母的时间太少了。每逢佳节倍思亲,我们流浪外在的游子应该深有感触。母亲,是世界上最伟大的人,她承载着对我们的爱,更是负担和压力。我们作为子女,只会嫌...

死锁的 4 种排查工具(死锁检测方法要解决两个问题)

死锁(DeadLock)指的是两个或两个以上的运算单元(进程、线程或协程),都在等待对方停止执行,以取得系统资源,但是没有一方提前退出,就称为死锁。死锁示例接下来,我们先来演示一下Java中最简...

1. 工厂模式详解(工厂模式示例)

我们的项目代码也是由简而繁一步一步迭代而来的,但对于调用者来说却是越来越简单化。简单工厂模式简单工厂模式(SimpleFactoryPattern)是指由一个工厂对象决定创建出哪一种产品类的实例。...

Jmeter(二十):jmeter对图片验证码的处理

jmeter对图片验证码的处理在web端的登录接口经常会有图片验证码的输入,而且每次登录时图片验证码都是随机的;当通过jmeter做接口登录的时候要对图片验证码进行识别出图片中的字段,然后再登录接口中...

取消回复欢迎 发表评论: