sql字查询
‘壹’ sql子查询可以再分组吗
肯定可以的。
子查询的结果集也是可以当作一个新的数据表看待,而在SQL语句中,任何数据集都是可以进行分组、排序等常规操作。
‘贰’ sql 子查询如何写
select id from 表A
full join
(select id,count(id) from 表B group by id)
on A.id=B.id
‘叁’ Sql server中, 什么是子查询.!
子查询是指将一条SQL Sever语句嵌入到另一条SQL Sever语句中。数据库引擎将子查询做为虚表执行查询操作。子查询可做为连接语句中的一个表,可做为选择语句中的一个值,也可以是SQL Sever查询子句,还可以是SQL Sever查询子句的字句,与数据操作语句混合在一起。 子查询的执行依赖于嵌套查询。查询树从最里层开始,一层一层向外执行。高层的嵌套查询可以访问低层嵌套查询的结果。
有两种子查询类型:标准和相关。标准子查询执行一次,结果反馈给父查询。相关子查询每行执行一次,由父查询找回。
举一个简单的例子:要找出“工程部”中工资超过该部门平均工资的员工的员工编号和姓名:
Select 员工编号,姓名
FROM 员工库
Where WORKDEPT = '工程部'
AND SALARY > (Select AVG(工资)
FROM 员工库
Where WORKDEPT = '工程部')
看懂没有?
‘肆’ sql 表中的子查询
select c.学号,c.姓名,d.分数,e.科目 from
student_info c,
(select a.学号,a.课程编号,b.分数 from grade a,(select 学号,max(分数) 分数 from grade group by 学号) b
where a.学号=b.学号 and a.分数=b.分数) d,
curriculum e,
where
c.学号=d.学号
and
d.课程编号=e.课程编号
‘伍’ SQL查询语句中,什么叫子查询
嵌套SELECT语句也叫子查询,一个
SELECT
语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select
list中,作为一个字段值来返回。
1、单行子查询
:单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=,
>,
<,
>=,
<=,
<>)来进行比较。
例:
select
ename,deptno,sal
from
emp
where
deptno=(select
deptno
from
dept
where
loc='NEW
YORK');
2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN"
操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL
和ANY
操作符不能单独使用,而只能与单行比较符(=、>、<
、>=
、<=
、<>)结合使用。
例:
1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字
sql>
select
stName
‘陆’ SQL查询语句中,什么叫子查询
嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select list中,作为一个字段值来返回。
1、单行子查询 :单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=, >, <, >=, <=, <>)来进行比较。
例:
select ename,deptno,sal
from emp
where deptno=(select deptno from dept where loc='NEW YORK');
2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可("IN" 操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL 和ANY 操作符不能单独使用,而只能与单行比较符(=、>、< 、>= 、<= 、<>)结合使用。
例:
1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字
sql> select stName
‘柒’ sql子查询和连接查询的区别是什么呢
1、子查询就如递归函数一样,有时侯使用起来能达到事半功倍之效,只是其执行效率同样较低,有时用自身连接可代替某些子查询,另外,某些相关子查询也可改写成非相关子查询。
2、表连接都可以用子查询,但不是所有子查询都能用表连接替换,子查询比较灵活,方便,形式多样,适合用于作为查询的筛选条件,而表连接更适合与查看多表的数据。
3、子查询是一种常用计算机语言SELECT-SQL语言中嵌套查询下层的程序模块。当一个查询是另一个查询的条件时,称之为子查询。
4、子查询是本质上就是一个完整 的SELECT 语句,它可以使一个 SELECT、SELECT...INTO 语句、INSERT...INTO 语句、DELETE 语句、或 UPDATE 语句或嵌套在另一子查询中。子查询的输出可以包括一个单独的值(单行子查询)、几行值(多行子查询)、或者多列数据(多列子查询)。
5、连接查询是关系数据库中最主要的查询,主要包括内连接、外连接和交叉连接等。通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志。
‘捌’ sql子查询
额,哥们,首先,你的表有没有主外键关系?其次,户表与人表中有一些什么字段,你得说清楚。
建表如下:
户口表(h) 人表(p)
nub 户号 pid 身份证号
address 住址 name 姓名
state 说明状态 relationship 家庭关系
nub 户号
introction 说明
state 状态
查询姓名、身份证号、家庭关系、户主、住址。
select p.name,p.pid,p.relationship,nvl((select p1.name from p p1 where p1.relationship like "是户主"),null) huzhuName,h.address
from p,h
where h.nub=p.nub;
nvl(old,new)如果有old值,返回old;否则返回new
上面那条子查询语句
select p1.name from p p1 where p1.relationship like "是户主"
是先查出关系是户主的人的名字,条件具体情况自己定(——)。
‘玖’ SQL server 中子查询的作用是什么
子查询的作用:
1、方便理解。
2、实现更复杂的查询。
3、提高查询效率。
扩展知识:
1、当直接从SQL的数据库中查询(列出)某些数据很困难或办不到时,可以通过从“查询结果集”中再次提取数据集来实现复合查询。这个“查询结果集”就被叫做子查询。
2、例,当表1与表2中以ID1关联,表2与表3以ID2关联,要以表1为基准复合查询三表中的数据时,就需要先查出表2与表3的子查询集,然后再与表1进行多表联查。
‘拾’ sql 分组子查询怎么写
你的意思是不是“找出所有status字段不是OK的BarCode,然后显示找到的这些BarCode对应的所有的记录”
比如:某个BarCode有三条记录,这三条记录中有一条status不是OK,那么就显示这三条记录;另一个BarCode有亮条记录,他们的status状态都是OK,那么就不显示。是这个意思不是。
如果是那么不需要分组,直接子查询就可以。
子查询的内容是查询status!='OK'(因为不知道是不是只有NG一种不OK的状态所以用了“不等于”,具体的要根据业务情况来定)的BarCode。
外层就是利用子查询查到的BarCode去查询就可以了,可以直接用in或者exist都可以。
比如某个编号为1111的有三条数据,其中有一条的status不是ok,那么子查询就会找到这条不是ok的记录,并返回编号1111,外层查询在利用编号1111,查到全部的三条记录。