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
里面查询的字段对应的是上面联合查询里面的字段。
到底这句话为什么这么写,我暂时还没明白,只知道要怎么来改。等我好好看看资料了,在回来重新编辑吧。