`
vtyi
  • 浏览: 83490 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

sql连接

阅读更多


join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。

其中 join_table 指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一个表操作的连接又称做自连接。

内连接 (INNER JOIN) 使用比较运算符进行表间某 ( ) 列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。

外连接分为左外连接 (LEFT OUTER JOIN LEFT JOIN) 、右外连接 (RIGHT OUTER JOIN RIGHT JOIN) 和全外连接 (FULL OUTER JOIN FULL JOIN) 三种。 与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表 ( 左外连接时 ) 、右表 ( 右外连接时 ) 或两个表 ( 全外连接时 ) 中所有符合搜索条件的数据行。

交叉连接 (CROSS JOIN) 没有 WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

连接操作中的 ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。

无论哪种连接都不能对 text ntext image 数据类型列进行直接连接,但可以对这三种列进行间接连接。例如:

SELECT p1.pub_id,p2.pub_id,p1.pr_info

FROM pub_info AS p1 INNER JOIN pub_info AS p2

ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)

 

( ) 内连接

内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种:

1 、等值连接: 在连接条件中使用等于号 (=) 运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。

2 、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括 > >= <= < !> !< <>

3 、自然连接: 在连接条件中使用等于 (=) 运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。

例,下面使用等值连接列出 authors publishers 表中位于同一城市的作者和出版社:

SELECT *

FROM authors AS a INNER JOIN publishers AS p

ON a.city=p.city

又如使用自然连接,在选择列表中删除 authors publishers 表中重复列 (city state)

SELECT a.*,p.pub_id,p.pub_name,p.country

FROM authors AS a INNER JOIN publishers AS p

ON a.city=p.city

 

( ) 外连接

内连接时,返回查询结果集合中的仅是符合查询条件 ( WHERE 搜索条件或 HAVING 条件 ) 和连接条件的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表 ( 左外连接时 ) 、右表 ( 右外连接时 ) 或两个边接表 ( 全外连接 ) 中的所有数据行。

如下面使用左外连接将论坛内容和作者信息连接起来:

SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b

ON a.username=b.username

 

下面使用全外连接将 city 表中的所有作者以及 user 表中的所有作者,以及他们所在的城市:

SELECT a.*,b.*

FROM city as a FULL OUTER JOIN user as b

ON a.username=b.username

 

( ) 交叉连接

交叉连接不带 WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

例, titles 表中有 6 类图书,而 publishers 表中有 8 家出版社,则下列交叉连接检索到的记录数将等

6*8=48 行。

SELECT type,pub_name

FROM titles CROSS JOIN publishers

ORDER BY type

二、 Hibernate 建立表结构

在前面基础知识得基础上我们来建立供我们演示得两张表(我们用 mysql 数据库作为学习用):


 

 

People

create table people(id bigint not null auto_increment,

name varchar(20),

primary key(id));

 

       location

create table location(id bigint not null auto_increment,

peopleId bigint not null,

addr varchar(20),

primary key(id,peopleId));

 

hibernate 影射文件:

         hibernate.cfg.xml 文件:

         

<session-factory>

 

        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>

        <property name="connection.url">jdbc:mysql://localhost:3306/relation</property>

        <property name="connection.username">root</property>

        <property name="connection.password">mysql</property>    

       

       <property name="show_sql">true</property>

       

        <mapping resource="org/test/bean/People.hbm.xml"/>

        <mapping resource="org/test/bean/Location.hbm.xml"/>

        

    </session-factory>

  

         People.hbm.xml 文件:

<class name="People" table="people">

       <id name="id" column="id">

           <generator class="native"/>

       </id>

       <property name="userName" type="string" column="name"/>

       <set name="locations" cascade="delete" inverse="true" lazy="false">

           <key column="peopleId"/>

           <one-to-many class="Location"/>

       </set>

    </class>

 

    Location.hbm.xml 文件 :
<class name="Location" table="location">

       <id name="id" column="id">

           <generator class="native"/>

       </id>

       <property name="addr" type="string" column="addr"/>

       <many-to-one name="people" column="peopleId" class="People" not-null="true"/>

    </class>

        

上面列出的都非常简单,不再解释。 Java 类源代码不再列出,很简单。

三、 Hibernate 连接查询

我们假设一种场景需要查询所有叫 Jack 或者地址为 BJ China 的人的信息。

经分析我们要用内连接查出两个表中 people.id   ==   location.peopleId 并且在 people 表中 name Jack 或者在 location 表中 addr shanghai 的人。

用习惯了 jdbc 的朋友也许一下就想到了如下语句:

select p.* from people p inner join location l on (p.name='Jack'or l.addr='BJ China')

and   p.id=l.peopleId

其实,在 hibernate api 中提供了对标准 sql 的支持,我们可以用 sql 语句来获得查询结果。 Hibernate 中还有另外两种种查询方法那就是 Query Criteria ,通过这两种方法我们可以轻松的写我们的 sql 语句,而不用关心到底用哪种连接。

下面我们就看一下如何分别用以上三种方法实现对我们要求的数据的读取:

首先,我们看一下用标准 sql 的做法:

 

session .createSQLQuery( "select p.* from people p inner join location l on (p.name='Jack' or l.addr='BJ China') and p.id=l.peopleId" )

 

执行这句话我们就可以读取到我们需求的数据,但是根据 api 我们知道, SQLQuery 返回的是一个实现了 SQLQuery 接口的对象,对我们来说没有直接的操作性。 如果我们直接用:

 

session .createSQLQuery( "select p.* from people p inner join location l on (p.name='Jack' or l.addr='BJ China') and p.id=l.peopleId " ).list();

 

来得到 list ,并对 list 里的对象进行转化为 People 对象时,我们会看到这样的抱错信息:

 

Exception in thread "main" java.lang.ClassCastException : [Ljava.lang.Object;

 

我们无法对数据进行操作,从 api 知道 SQLQuery 继承自 Query 接口,那么我们可不可以用 Query 的标准方法操作返回数据呢?我们可以对程序作如下改造即可得到我们需要的可以后续操作的数据:

 

Query query =  session .createSQLQuery( "select p.* from people p inner join location l on p.name='Jack' and p.id=l.peopleId or l.addr='BJ China'" ).addEntity(People. class );

 

这样结果可以和我们就可以对结果进行操作了,不再多说。

 

接下来我们看一下我们怎么用 Hibernate 特色的 sql 语言来获取数据:

 

Query query = session .createQuery( "select p from People p,Location l where (p.userName='Jack' or l.addr='BJ China') and p.id=l.people.id" );

 

有没有觉得太大的不同呢?我们不再需要“ inner join ”,而是直接从两个类里边读取符合条件的对象。

 

最后我们看一下 Hibernate 如何用 Criteria 进行连接查询:

 

Criteria criteria = session .createCriteria(People. class )                          .createAlias( "locations" , "location" )

                  .add(Restrictions.or (Restrictions.eq ( "userName" , "Jack" ), Restrictions.eq ( "location.addr" , "BJ China" )));

分享到:
评论

相关推荐

    【大厂面试专栏】一份Java程序员需要的技术指南,这里有面试题、系统架构

    【大厂面试专栏】一份Java程序员需要的技术指南,这里有面试题、系统架构、职场锦囊、主流中间件等,让你成为更牛的自己!_technology-talk

    flashocc-QAT-PTQ.zip

    flashocc-QAT-PTQ.zip

    大连理工大学城市学院在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    川北医学院在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    黑河学院在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    西安邮电大学在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    【光学】基于matlab两列单色平面波+合成【含Matlab源码 9007期】.zip

    CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、物理应用 仿真:导航、地震、电磁、电路、电能、机械、工业控制、水位控制、直流电机、平面电磁波、管道瞬变流、刚度计算 光学:光栅、杨氏双缝、单缝、多缝、圆孔、矩孔衍射、夫琅禾费、干涉、拉盖尔高斯、光束、光波、涡旋 定位问题:chan、taylor、RSSI、music、卡尔曼滤波UWB 气动学:弹道、气体扩散、龙格库弹道 运动学:倒立摆、泊车 天体学:卫星轨道、姿态 船舶:控制、运动 电磁学:电场分布、电偶极子、永磁同步、变压器

    文件比较工具、文件夹比较工具、linux、ubuntu、linx麒麟等免费使用多日

    文件比较工具、文件夹比较工具、linux、ubuntu、linx麒麟等免费使用多日

    Spire.XLS是一个基于.NET的组件,使用它我们可以创建Excel文件

    Spire.XLS是一个基于.NET的组件,使用它我们可以创建Excel文件,编辑已有的Excel并且可以转换Excel文件.zip

    【Unity完整游戏模板】Downhill Ride 轻松开发极限运动或竞速类的下坡滑行游戏

    文件名:Downhill Ride - Game Template 2020 LTS v1.2.3.unitypackage Downhill Ride - Game Template (2020 LTS) 是一个为 Unity 2020 LTS 版本开发的完整游戏模板,主要适用于开发极限运动或竞速类的下坡滑行游戏。这个模板专为快速原型设计和项目开发而打造,提供了关键功能和资源,帮助开发者轻松实现类似下坡竞速的游戏项目。 主要特点: 完整的游戏框架: 该模板包含基础的游戏逻辑,允许玩家通过控制角色在下坡道上滑行或骑行,避开障碍物并尽可能快速完成赛道。 物理与控制系统: 内置的物理引擎和角色控制器已经经过优化,可以实现平滑的下坡滑行体验,提供真实感十足的物理效果。 多种关卡支持: 模板支持多个关卡设计,开发者可以根据需要扩展或自定义不同难度的关卡。 UI 和交互设计: 包含基本的用户界面(UI)设计,带有主菜单、关卡选择、计分系统等功能,用户可以轻松扩展或定制这些 UI 元素。 优化的性能: 模板专为移动平台和桌面平台优化,确保良好的性能表现......

    Java课程设计之销售管理系统

    (1)课程设计项目简单描述 鉴于当今超市产品种类繁多,光靠人手动的登记已经不能满足一般商家的需求。我们编辑该程序帮助商家完成产品、商家信息的管理,包括产品、客户、供应商等相关信息的添加、修改、删除等功能。 (2)需求分析(或是任务分析) 1)产品类别信息管理:对客户的基本信息进行添加、修改和删除。 2)产品信息管理:对产品的基本信息进行添加、修改和删除。 3)供应商信息管理: 对供应商的基本信息进行添加、修改和删除。 4)订单信息管理:对订单的基本信 息进行添加、修改和删除。 5)统计报表:按选择日期期间,并按产品类别分组统 计订单金额,使用表格显示统计结果

    常州大学在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    yolo算法-工地佩戴头盔数据集-1608张图像带标签-epi-d4clr.zip

    yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值

    Android System Webview(com.google.android.webvie) 125.0.6422.82

    Android System Webview(com.google.android.webvie) 125.0.6422.82 一般情况下设备可以从google play上更新,但是google play 中没有历史版本下载,所以在自己需要之后把资源上传

    VLP超低轮廓铜箔,全球前10强生产商排名及市场份额(by QYResearch).docx

    VLP超低轮廓铜箔,全球前10强生产商排名及市场份额(by QYResearch).docx

    南宁学院在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    PPServ是一个Web开发集成环境,可以使用Apache,PHP,Mysql创建Web应用 -PPServ.zip

    网鼎杯PPServ是一个Web开发集成环境,可以使用Apache,PHP,Mysql创建Web应用。_PPServ.zip

    沧州交通学院在四川2020-2024各专业最低录取分数及位次表.pdf

    那些年,与你同分同位次的同学都去了哪里?全国各大学在四川2020-2024年各专业最低录取分数及录取位次数据,高考志愿必备参考数据

    windows 安装包Miniconda3-py38-4.11.0-Windows-x86-64

    windows 安装包Miniconda3-py38-4.11.0-Windows-x86-64

    yolo算法-公路等级数据集-8188张图像带标签-汽车客车摩托highway-classification.zip

    yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值

Global site tag (gtag.js) - Google Analytics