mysql_数据查询_单表查询
1.单表查询:
1.1选中表中若干列:
SELECT子句的<目标列表达式>可以是表中属性列,也可以是表达式,还可以是字符常量。
SELECT Sname,'year of birth:',2014-Sage FROM student;
1.2选定表中若干行:
1.去掉重复行:
想要去除查询结果中重复的行,可以使用DISTINCT,没有DISTINCT,则默认为ALL,即保留重复。
SELECT DISTINCT Sno FROM SC;
2.查询满足条件的元组:
a.比较大小
SELECT Sname FROM Student WHERE Sdept='CS';
SELECT Sname,Sage FROM Student WHERE Sage<20;
b.确定范围:
使用谓词BETWEEN……AND……和NOE BETWEEN……AND……查询属性值在(或不在)指定范围的元组
SELECT Sname,Sdept,Sage FROM Student WHERE Sage BETWEEN 20 AND 23;
SELECT Sname,Sdept,Sage FROM Student WHERE Sage NOT BETWEEN 20 AND 23;
c.确定集合:
谓词IN可以用来属性值属于指定集合的元组。
SELECT Sname,Ssex FROM Student WHERE Sdept IN ('CS','BS','AS');
SELECT Sname,Ssex FROM Student WHERE Sdept NOT IN ('CS','BS','AS');
d.字符串匹配:
谓词LIKE可以用于字符串匹配
一般语法格式:[NOT] LIKE '<匹配串>' [ESCAPE'<换码字符>']
通配符:
%(百分号):表示任意长度(可为0)的字符串
_(下划线):表示任意单个字符
如果用户要查询的字符串中本身就含有%或_,这时就要用ESCAPE'<换码字符>'对通配符转义。
SELECT Cno,Ccredit FROM Course WHERE Cname LIKE 'DB\_Design' ESCAPE'\' ;
自己在mysql上亲测,貌似不能用ESCAPE。
e.涉及空值的查询:
SELECT Sno,Cno FROM SC WHERE Grade IS NULL;
SELECT Sno,Cno FROM SC WHERE Grade IS NOT NULL;
f.多重条件查询:
逻辑运算符AND和OR可用来连接多个查询条件。AND优先级高于OR,可用括号改变优先级。
谓词IN是多个OR运算符的缩写。
SELECT Sname,Ssex FROM Student WHERE Sdept='CS' AND Sage<20;
3.ORDER BY子句
用户可用 ORDER BY 子句对查询结果按照一个或多个属性列的升序(ASC)或降序(DESC)排序,默认值为升序。对于空值的处理,根据系统而定。
SELECT * FROM Student ORDER BY Sdept,Sage DESC;
4.聚集函数:
COUNT(*)
COUNT([DISTINCT|ALL] <列名>)
SUM([DISTINCT|ALL] <列名>)
AVG([DISTINCT|ALL] <列名>)
MAX([DISTINCT|ALL] <列名>)
MIN([DISTINCT|ALL] <列名>)
SELECT COUNT(*) FROM Student;
SELECT COUNT(DISTINCT Sno) FROM SC;
当聚集函数遇到空值时,除COUNT(*)外,都跳过空值只处理非空值。
注:WHERE子句中是不能用聚集函数作为条件表达式的。聚集函数只能用于SELECT子句和GROUP BY中的HAVING子句。
5.GROUP BY
GROUP BY 子句将查询结果按某一列或多列的值分组,值相等的为一组。
对查询结果分组的目的是为了细化聚集函数的作用对象。如果未对查询结果分组,聚集函数将作用于整个查询结果。分组后聚集函数将作用于每一组,即每一组都有一个函数值。
SELECT COUNT(Sno) FROM student GROUP BY Sdept;
如果分组后还要求按一定的条件对这些组进行筛选,最终只输出满足指定条件的组,则可以使用HAVING短语指定筛选条件。
SELECT Sno FROM SC GROUP BY Sno HAVING COUNT(*)>=2;
先用 GROUP BY 子句按Sno进行分组,再用聚集函数COUNT对每一组进行计数;HAVING短语给出了选择组的条件,只用满足条件才会被选择出来。
注:WHERE子句和HAVING短语的区别在于作用对象不同。WHERE子句作用于基本表或视图,从中选择满足条件的元组。 HAVING短语作用于组,从中选择满足条件的组。
WHERE子句中不能使用聚集函数作为条件表达式。
SELECT Sno FROM SC GROUP BY Sno HAVING AVG(Grade)>=80;
mysql_数据查询_单表查询的更多相关文章
- SQL基本查询_单表查询(实验二)
SQL基本查询_单表查询(实验二) 查询目标表结构及数据 emp empno ename job hiedate sal comn deptno 1007 马明 内勤 1992-6-12 4000 2 ...
- MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询
MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...
- MySQL简单查询和单表查询
MySQL记录操作 概览 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用 ...
- SQL基本查询_多表查询(实验三)
SQL基本查询_多表查询(实验三) 题目要求(一) 针对emp.dept两表完成如下查询,并验证查询结果的正确性 使用显式内连接查询所有员工的信息,显示其编号.姓名.薪水.入职日期及部门名称: 使用隐 ...
- SQL基础--查询之一--单表查询
SQL基础--查询之一--单表查询
- MySQL数据查询之单表查询
单表查询 简单查询 - 创建表 DROP TABLE IF EXISTS `person`; CREATE TABLE `person` ( `id` ) NOT NULL AUTO_INCREMEN ...
- 查询数据SELECT 之单表查询
一.单表查询的语法与关键字的执行优先级""" # 单表查询# 单标查询完整与法:# select distinct(关键字,代表查询的意思,后面跟)字段1,字段2...( ...
- SQL数据查询之——单表查询
一.SQL数据查询的一般格式 数据查询是数据库的核心操作.SQL提供了SELECT语句进行数据查询,其一般格式为: SELECT [ALL | DISTINCT]<目标列表达式>[,< ...
- (七)MySQL数据操作DQL:单表查询1
(1)单表查询 1)环境准备 mysql> CREATE TABLE company.employee5( id int primary key AUTO_INCREMENT not null, ...
随机推荐
- 记一次 Hibernate 插入数据中文乱码报错解决
错误描述 程序运行,向表中插入数据(包含中文)报错:\xE6\xB2\x88\xE9\x9B\xAA... 但是自己另外新建一个数据库手动插入数据中文正常,同样修改数据库,表的编码之后同样不行.而且 ...
- Ubuntu 16.04安装Sublime Text3
1.安装: sudo add-apt-repository ppa:webupd8team/sublime-text-3 sudo apt-get update sudo apt-get instal ...
- Linux: 查找使用中的port
找出所有使用中的port netstat -tulpn 输出 Active Internet connections (only servers) Proto Recv-Q Send-Q Local ...
- c++中的set_new_handler和new_handler
当operator new申请一个内存失败的时候,它会进行如下的处理步骤: 1.如果存在客户指定的处理函数,则调用处理函数(new_handler),如果不存在则抛出一个异常. 2.继续申请内存 ...
- Lotto(DFS处理)
题目再现 题目内容: 给定N个数字,再从中选定M个数字出来. 将每一种组合内的数字由小到大排列之后, 将全部组合依照字典序排列. 请你找出第X组的第Y个数字. 给定的数字为1~N. 范例1 (N,M, ...
- Win7 如何卸载IE9
1 控制面板,卸载程序 2 查看已安装的更新 3 右击对应更新,选择卸载.
- Java中的equals()和hashCode()
概述 在我们使用类集框架(比方使用hashMap.hashSet)的时候,常常会涉及到重写equals()和hashCode()这两个方法. 这两个方法的联系是: 1. 假设两个对象不同,那么他们的h ...
- 【UI自动化方面】
1.自动化执行失败如何排查故障. 答:1).查看log,错误原因.[log不详细的话,可以优化] 2).排查是否真的有bug,若不是bug查看是否是新版本引入了新的变更. 3).调试脚本看自己脚本是不 ...
- HDU 1159 Common Subsequence (动规+最长公共子序列)
Common Subsequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- Codeforces Round #250 (Div. 1) D. The Child and Sequence 线段树 区间求和+点修改+区间取模
D. The Child and Sequence At the children's day, the child came to Picks's house, and messed his h ...