数据库中单表的查询(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
  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个数据库系统 SQL Server 实验单表查询的实验结果分析。 单表查询实验通常旨在通过 SQL 语句查询单个表格的数据,并对查询结果进行分析和解释。在 SQL Server ,可以使用 SELECT 语句来进行单表查询,例如: ``` SELECT * FROM tableName; ``` 这个语句将检索表格的所有数据,并将其返回到查询结果。 在单表查询实验,你可以执行多种类型的查询,例如: 1. 简单查询:使用基本的 SELECT 语句查询表格的数据。例如: ``` SELECT firstName, lastName FROM employees; ``` 这个查询将返回表格所有员工的名字和姓氏。 2. 条件查询:使用 WHERE 子句过滤表格的数据。例如: ``` SELECT * FROM employees WHERE department = 'Sales'; ``` 这个查询将返回所有在销售部门工作的员工的信息。 3. 聚合查询:使用聚合函数(如 COUNT、AVG、MAX、MIN 和 SUM)对表格的数据进行计算。例如: ``` SELECT COUNT(*) FROM employees; ``` 这个查询将返回表格员工的总数。 4. 排序查询:使用 ORDER BY 子句对查询结果进行排序。例如: ``` SELECT * FROM employees ORDER BY hireDate DESC; ``` 这个查询将返回按照入职日期降序排列的所有员工信息。 在分析单表查询实验结果时,你需要考虑以下因素: 1. 查询语句的正确性:确保查询语句正确无误,并且可以返回你所期望的结果。 2. 查询结果的准确性:分析查询结果,确保其包含完整、准确的数据。 3. 查询效率:评估查询语句的执行效率,尤其是对大型数据集进行查询时。 4. 数据库性能:分析查询数据库性能的影响,例如查询语句是否会锁定表格或影响其他查询的执行。 通过对这些因素进行分析,你可以更好地理解单表查询实验的结果,并对数据库系统的性能和优化提出建议。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值