首页 > 数据库 >数据库中单表的查询(select)

数据库中单表的查询(select)

时间:2024-07-22 19:27:44浏览次数:16  
标签:-- 数据库 score 单表 student sid where select

单表查询

所有的查找都会得到一张虚拟表

一、 最简单的查询
SELECT 123;
SELECT 'asd';
SELECT 1+1;
二、 从表中获取数据
select 字段名,字段名 from 表名 
2.1 全字段查询
SELECT sid,sname,birthday,ssex,classid FROM student;
SELECT * FROM student;     -- 使用*不利于sql优化,不推荐
2.2 部分字段查询
SELECT sname,ssex FROM student;
2.3 字段名起别名
select sname as '姓名',birthday '生日', ssex 性别 from student;
2.4 添加字段
select sname,'yjy' 学校 from student
2.5 distinct
-- 所有的字段的数据要一致才会去重
   select distinct sid,sname,ssex from student
2.6 带条件的查询
(1)where 子句
	过滤查询结果,以仅返回满足特定条件的记录
select * from student where sid=5;
select * from student where sid<>5;
select * from student where sid>5;
select * from student where sid between 3 and 6;
示例:
-- 查找1班的女同学
   select * from student where classid=1 and ssex='女';

-- 查询 年龄 大于1990-1-1 的学生
   select * from student where birthday < '1990-1-1';
(2)in 
	在某个特定的范围
-- 3  5  7  9
-- or 会让索引失效
	select * from student where sid = 3 or sid = 5 or sid = 7 or sid = 9;
-- 推荐 
-- in 可以用到索引
	select * from student where sid in(3,5,7,9)
(3)like 
	模糊查询
	模糊符号:
	a. % 任意多的任意字符
	b. _ 一个任意字符
insert into student(sname) values('杨佳佳'),('小杨'),('杨同学');

insert into student(sname) values('帅气的杨同学');

select * from student where sname like '%杨%'

select * from student where sname like '杨%'

select * from student where sname like '%杨'

select * from student where sname like '杨_'

select * from student where sname like '杨__'   -- 两个下划线
(4)null
select * from student where birthday is null

select * from student where birthday is not null
2.7 聚合函数
把多个值变为一个值
	a.count() 统计个数
	b.max() 求最大值
	c.min() 求最小值
	d.sum() 求总和
	e.avg() 求平均数
-- count 不统计null
-- select count(字段\常量\*) from 表名
	select count(sid) from student;	-- 主键

	select count(classid) from student;	-- 不统计null

	select count('a') from student;		-- 不推荐

	select count(1) from student;	-- 推荐

	select count(*) from student;	-- 推荐
-- sum avg min max  数值类型
	select sum(score) from sc;

	select avg(score) from sc;

	select max(score) from sc;

	select min(score) from sc;
示例:
-- 统计出成绩表中一共有多少次考试,总成绩,平均分,最高分,最低分
   select count(*),sum(score),avg(score),max(score),min(score) from sc;
2.8 分组 group by
对所有的数据进行分组统计,分组的依据字段可以有多个,并依次分组
-- 统计各班有多少人
   select classid,count(1) from student group by classid 

-- 成绩表 统计每个同学的 总分和平均分
   select sid,sum(score),avg(score) from sc group by sid
2.9 having
与group by结合使用,进行分组后的数据筛选
-- 查询平均分不及格的sid
   select sid ,sum(score),avg(score) from sc group by sid having avg(score) < 60
2.10 order by 排序
(1)按照先写的字段排序,如果有相同的按照下一个字段排序
(2)升序 asc(默认)
(3)降序 desc 必须声明
示例:
select * from student order by classid desc;	-- desc:降序
select * from student order by classid asc; -- asc:升序
select * from sc order by score desc,cid desc;
2.11 limit 分页

0 开始 (页码-1)*步长,步长

-- select * from student limit 位置,步长
   select * from student limit  6,3

-- 应用层解决
-- select * from student limit (3-1)*3,3  错误的

-- 找到成绩及格的总分数排名第二的  
   select sid,sum(score) from sc where score>=60 group by sid  order by sum(score) desc limit 1,1

标签:--,数据库,score,单表,student,sid,where,select
From: https://blog.csdn.net/m0_65347933/article/details/140617353

相关文章

  • 数据库迁移的神秘面纱:Liquibase异常全解析与解决之道
    哈喽,大家好,我是木头左!一、Liquibase简介与重要性Liquibase,这个名字听起来就像是液体的魔法。在软件开发的世界里,它确实是一种魔法,一种让数据库变更变得清晰、可控甚至可逆的魔法。但就像所有魔法一样,掌握它需要了解它的规则和秘密。今天,就来揭开Liquibase的神秘面纱,特别是那些......
  • SQL实战宝典:快速上手数据库查询与优化
    文章目录SQL速成手册SQL的主要功能1、基本查询语句2、表操作语句3、数据操作语句4、函数与聚合操作5、子查询与联接6、高级操作7、性能优化与安全性基本查询语句表操作语句数据操作语句函数与聚合操作子查询与联接高级操作性能优化与安全性SQL速成手册SQL(Struct......
  • 数据库_duckdb_读取csv创建表等案例
    duckdbduckdb读取csv格式文件duckdb连接数据库-创建表duckdb将数据转换为dataframedataframeapplymergegroupby代码示例#!/usr/bin/envpython3#-*-coding:UTF-8-*-#---------------------------importduckdbimportosif__name__=="__main__":......
  • django 数据库迁移结束之后,就执行的代码
    在你需要的app下面创建signals.py文件该文件下写出你需要执行的函数或类例如fromdjango.dbimporttransactionfromuserimportmodelsfromloggerimportlogclassCreatePermissions(object):@staticmethoddefcreate_permissions(sender,**kwargs):......
  • 有没有办法让用户输入 url 查询并使用单个函数过滤数据库?
    我正在使用DjangoRest框架和PostgreSQL,构建一个返回本NBA赛季所有统计数据的API。不是有一个函数来返回每个类别的统计信息,例如:@api_view(['GET'])defsortByRebounds(request):"""Returnsallstatsinthedatabasesortedbyreboundspergame"""strin......
  • SpringBoot+ Sharding Sphere 轻松实现数据库字段加解密
    一、介绍在实际的软件系统开发过程中,由于业务的需求,在代码层面实现数据的脱敏还是远远不够的,往往还需要在数据库层面针对某些关键性的敏感信息,例如:身份证号、银行卡号、手机号、工资等信息进行加密存储,实现真正意义的数据混淆脱敏,以满足信息安全的需要。那在实际的业务开发过程......
  • windows定期备份数据库脚本
    1.打开任务计划程序按Win+R,输入taskschd.msc并按回车,打开任务计划程序。2.创建基本任务在任务计划程序右侧,点击“创建基本任务...”。输入任务名称(如“备份MySQL数据库”)和描述,然后点击“下一步”。3.选择触发器选择“每天”,然后点击“下一步”。设置任务开始......
  • zabbix_appliance的数据库扩容方案
    问题:zabbix_appliance直接加载虚拟机来部署zabbix是很方便的办法,下载配置好后,监控一段时间会提示mysql存储空间不足,进去系统df一看才4G多,只好自已手动扩容.思路:虚拟机上添加一块硬盘,创建新分区并挂载到扩容目录,迁移mysql的数据库目录到扩容目录,修改mysql\php\zabbix的......
  • SpringBoot利用MyBatis连接Mysql数据库时常见启动报错
    目录报错情况报错情况一:​编辑报错情况二:解决步骤一、解决命名问题1.mapper层的id是否和Dao层的方法名字相同2.检查namespace与Dao层的文件地址相同二、解决注解问题1.检查Controller层的注解是否正确和完整2.Dao层或者Mapper层的注解3.pojo层:实体类层Data注解(用来......
  • Oracle——navicat连接Oracle数据库报错(12514)
    2024/07/221.问题描述2.解决办法3.参考材料1.问题描述与其他厂商做数据对接时,对方提供相关视图,我navicat连接Oracle数据库时报错,其报错代码如下:ORA-12514:TNS:listenerdoesnotcurrentlyknowofservicerequestedinconnectdescriptor2.解决办法对方提供实例为hisd......