04多表查询

多表查询

一、概述

从多张表中查询需要的数据。

语法:select 列名列表 from 表名列表 where 条件;

分类:内连接查询,外连接查询,子查询。

笛卡尔积:

有两个集合A,B,取这两个集合的所有组成情况。

要完成多表查询,需要消除无用的数据。

二、内连接查询(交集)

1.隐式内连接

select * form emp,dept where emp.dept_id = dept.id;

一般情况下,我们只需要查询部分字段,把*替换成相应的字段列名称即可。emp.name,dept.name,简便书写可以给表起别名:select t1.name,t2.name from emp t1,dept t2 where t1.dept_id=t2.id;

2.显式内连接

语法:select 字段列表 from 表名1 [inner] join 表名2 on 条件;(inner可以省略)

select * from emp inner jofin dept on emp.'dept_id'=dept.'id';

内连接查询

从哪些表中查

条件是什么

查询哪些字段

三、外连接查询

1.左外连接(左表以及两表交集)

语法:select 字段列表 from 表1 left [outer] join 表2 on 条件;

查询所有员工信息,如果员工有部门,则查询部门名称,没有部门,则不显示部门。

select t1.*,t2.name from emp t1 left join dept t2 on t1.dept_id=t2.id;

2.右外连接(右表以及两表交集)

语法:select 字段列表 from 表1 right [outer] join 表2 on 条件;

查询所有员工信息,如果员工有部门,则查询部门名称,没有部门,则不显示部门。

select t1.*,t2.name from emp t1 right join dept t2 on t1.dept_id=t2.id;

四、子查询

概念:查询中嵌套查询,称嵌套查询为子查询。

查询工资最高的员工信息。

select * from emp where emp.salry=(select max(salary) from emp);

子查询的不同种情况
  • 子查询的结果是单行单列的

    子查询可以作为条件,使用运算符去判断> < >= <= =。查询小于平均工资的人:select * from emp where emp.salary<(select avg(salary) from emp);

  • 子查询的结果是多行单列的

    子查询可以作为条件,使用运算符in判断(查询结果为集合)查询财务部和市场部所有员工信息:select * from emp where dept_id in(select id from dept where name=“财务部” or name=“市场部”);

  • 子查询的结果是多行多列的

    子查询可以作为一张虚拟表。可以进行表的查询。

    查询员工入职日期是2011-11-11日之后 的员工信息和部门信息:select * from dept t1,(select * from emp where emp.join_date >“2011-11-11”) t2 where t1.id=t2.dept_id;

    普通查询:select * from emp t1 ,dept t2 where t1.dept_id = t2.id and t1.join_date >“2011-11-11”;

看实例学VFP:更复杂的查询 时间:2009-02-12来源:编程入门网 作者:老马   在看实例学VFP:对中记录进行定位与查找操作及看实例学VFP:用SELECT语句创建查询这两个例子中,我们可以在查询时可以从组合框中选定一个要查询的字段。本例对这种查询方式再做进一步改进,使之在查询时不仅可以从一个组合框中选取要查询的字段,还可以从另一个组合框中选定操作符(如<、=、>等),从而实现更复杂的查询。本例应用到了数据环境,并使用“数据1”数据库中的“人员信息”作为数据环境的数据源,关于该数据库的情况已经在看实例学VFP:示例数据库一文中给出,这里不再详述。运行界面见本文末尾。   制作步骤如下:   一、新建单,将其caption属性值设置为“更复杂的查询例子”,AutoCenter属性值设置为.T.,width属性值设置为520,height属性值设置为245,并保存为“更复杂的查询例子.scx”。   二、右击单空白处,选“数据环境”命令,将“人员信息”添加到数据环境中。在“数据环境设计器”中拖动“人员信息”的标题栏到单上,自动生成一个格控件。由于是从数据环境中把“人员信息”拖动过来由系统自动生成的,该格控件的RecordSource属性及RecordSourceType属性已经由系统设置好了,不用管它,但name属性值系统给出的好长,为了书写代码的方便,我们把这个格控件的name属性值修改为“grid1”。   三、在格控件的下方添加一个Label控件,并把它的caption属性值设置为“查询条件”。   四、在label控件的右侧依次添加两个组合框控件、一个文本框控件及两个命令按钮command1和command2,并把这两个命令按钮的caption属性值依次设置为“查找”和“退出”。   五、适当调整各控件在单上的位置,调整后的单设计器如下图所示:   六、设置组合框控件的属性:   (一)组合框Combo1:RecordSourceType属性值设置为“8-结构”,RecordSource属性值设置为“人员信息”。   (二)组合框Combo2:RecordSourceType属性值设置为“1-值”,RecordSource属性值设置为“,>,<,=,>=,<=,<>”。   七、添加事件代码:   (一)单的unload事件代码:close data   (二)组合框Combo1的InteractiveChange事件代码: if alltrim(this.displayvalue)="出生日期" thisform.text1.value={} else thisform.text1.value='' endif   (三)“查找”按钮command1的click事件代码: if thisform.grid1.recordsource='临时人员信息' thisform.grid1.recordsource='人员信息' endif' private CXTJ if empty(thisform.combo1.displayvalue) or empty(thisform.combo2.displayvalue) ; or empty(thisform.text1.value) && 判断列框和文本框是否为空 messagebox('请输入完整条件!',16,'系统提示') thisform.combo1.setfocus else do case case alltrim(thisform.Combo1.Displayvalue)='基本工资' CXTJ=alltrim(thisform.combo1.displayvalue); +' '+alltrim(thisform.combo2.displayvalue); +' '+alltrim(thisform.text1.value) case alltrim(thisform.Combo1.Displayvalue)='出生日期' CXTJ=alltrim(thisform.combo1.displayvalue); +' '+alltrim(thisform.combo2.displayvalue); +' ctod("'+dtoc(thisform.text1.value)+'")' otherwise CXTJ=alltrim(thisform.combo1.displayvalue); +' '+alltrim(thisform.combo2.displayvalue); +' "'+alltrim(thisform.text1.value)+'"' endcase Select * from 人员信息 where &CXTJ. into cursor 临时人员信息 thisform.grid1.recordsource='临时人员信息' thisform.grid1.backcolor=rgb(200,224,248) endif   (四)“退出”按钮command2的click事件代码:thisform.release   八、运行“更复杂的查询例子.scx”,界面见下图:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值