联合查询SQL语句和翻页语句

本文介绍了SQL中的四种联合查询类型:内联、左联、右联和全联,强调了联合查询在效率上的优势,并给出了具体的示例。同时,提到了SQL翻页语句的应用,探讨了如何结合联合查询实现数据检索的分页展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SQL联合查询一开始看的参考资料如下:

SQL联合查询中的关键语法

联合查询效率较高.以下例子来说明联合查询的好处

t1表结构(用户名,密码) userid int username varchar(20) password varchar(20)

                  1        jack              jackpwd

                  2        owen              owenpwd

t3表结构(用户积分,等级) userid int jf int dj int

                    1      20   3

                    3      50   6

第一:内联(inner join)

如果想把用户信息,积分,等级都列出来.那么一般会这样写

select * from t1 ,t3 where t1.userid = t3.userid 其实这样的结果等同于select *
from t1 inner join t3 on t1.userid=t3.userid

就是把两个表中都存在userid的行拼成一行.这是内联.但后者的效率会比前者高很多.建议用后者的写法.

运行结果:userid username password userid jf dj

      1     jack     jacjpwd  1    20 3

第二:左联(left outer join)显示左表中的所有行

select * from t1 left outer join t3 on t1.userid=t3.userid

运行结果:userid username password userid jf dj

       1      jack    jackpwd   1    20  3

       2      owen    owenpwd  NULL NULL  NULL

第三:右联(right outer join)显示右表中的所有行

select * from t1 right outer join t3 on t1.userid=t3.userid

运行结果:userid username password userid jf dj

       1     jack     jackpwd   1   20  3

       Null  Null     Null      3   50  6

第四:全联(full outer join)显示两边表中所有行

select * from t1 full outer join t3 on t1.userid=t3.userid

运行结果:userid username password userid jf dj

        1    jack     jackpwd  1     20 3

        2    owen     owenpwd  NULL NULL   NULL

        Null Null     Null     3     50     6

总结,关于联合查询,本人已测试过.效率的确比较高,4种联合方式如果可以灵活使用,基本上复杂的语句结构也会简单起来.这4种方式是:
Inner join
left outer join
right outer join
full outer join
来自:[http://www.cnblogs.com/aaapeng/archive/2010/01/20/1652151.html]

回到自己的东西上来,自己写了一句:

select FILE_DATE from PRISONER LEFT JOIN PRISONER_IMAGE ON PRISONER.ID = PRISONER_IMAGE.PRISONER_ID WHERE PRISONER_IMAGE.ID=?

这里只查询了一个字段,如果要查多个表中的不同字段,需要填入表的名称,如下:

select PRISONER_IMAGE.ID,PRISONER.PRISONER_CODE from PRISONER LEFT JOIN PRISONER_IMAGE ON PRISONER.ID = PRISONER_IMAGE.PRISONER_ID WHERE NAME =? and PRISONER_IMAGE.ID is not null

后面的PRISONER_IMAGE.ID is not null定义的是查出的数据中,PRISONER_IMAGE.ID需要有值。

下面是关于翻页的SQL语句:

String conditoin = "";
        List<Object> conditionList = new ArrayList<Object>();

        conditionList.add(page * limit);
        conditionList.add((page - 1) * limit);

        String sql = "select START_TIME,END_TIME,ADDRESS,TYPE,NAME,PEOPLE_NUM,UPDATE_TIME,ADD_TIME,UNIT from ("
                + "select row_.*,ROWNUM rownum_ from("
                + "select EDUCATION.START_TIME,EDUCATION.END_TIME,EDUCATION.ADDRESS,EDUCATION.TYPE"
                + ",POLICE.NAME"
                + ",EDUCATION.PEOPLE_NUM,EDUCATION.UPDATE_TIME,EDUCATION.ADD_TIME,EDUCATION.UNIT "
                + "from EDUCATION LEFT JOIN POLICE ON EDUCATION.POLICER = POLICE.ID"
                + conditoin
                + " order by EDUCATION.UNIT desc) row_ where ROWNUM<=?) where rownum_>?";

其中的

"select EDUCATION.START_TIME,EDUCATION.END_TIME,EDUCATION.ADDRESS,EDUCATION.TYPE"
                + ",POLICE.NAME"
                + ",EDUCATION.PEOPLE_NUM,EDUCATION.UPDATE_TIME,EDUCATION.ADD_TIME,EDUCATION.UNIT "
                + "from EDUCATION LEFT JOIN POLICE ON EDUCATION.POLICER = POLICE.ID"

是联合查询语句。

select START_TIME,END_TIME,ADDRESS,TYPE,NAME,PEOPLE_NUM,UPDATE_TIME,ADD_TIME,UNIT

里面查询的字段对应的是上面联合查询里面的字段。

到底这句话为什么这么写,我暂时还没明白,只知道要怎么来改。等我好好看看资料了,在回来重新编辑吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值