❤️作者主页:微凉秋意
✅作者简介:后端领域优质创作者🏆,CSDN内容合伙人🏆,阿里云专家博主🏆
✨精品专栏:C++面向对象
🔥系列专栏:JavaWeb
文章目录
上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。
对于主外键的关系搞不清楚的可以参考我以往的博文:mysql一点通
有如下两张表格,t_people(人)与t_passport(护照):


一个人对应一本护照,同时一本护照对应一个人,而且人不一定有护照,有护照一定会有人存在。
因此外键应设在护照表中,那么就该创建类了:
// Passport:
public class Passport {
private Integer passportId;
private String passportSerial;
}
// People
public class People {
private Integer peopleId;
private String peopleName;
private Passport passport;
}
这样创建非常符合表之间的逻辑关系,但是创建方式并不唯一。
在Passport类中添加People属性也是可以的,即:
// Passport
public class Passport {
private Integer passportId;
private String passportSerial;
private People people;
}
// People
public class People {
private Integer peopleId;
private String peopleName;
}
那实际做项目时应该如何取舍?答案是根据需求:
这里以查询公民以及其对应的护照信息为例,编写项目:
在mapper接口定义方法:
public interface PeopleMapper {
List<People> selectAll();
}
在xml中编写sql:
<mapper namespace="com.qj.mapper.PeopleMapper">
<resultMap id="peopleMap" type="People">
<id property="peopleId" column="people_id"/>
<result property="peopleName" column="people_name"/>
<association property="passport" javaType="Passport">
<id property="passportId" column="passport_id"/>
<result property="passportSerial" column="passport_serial"/>
</association>
</resultMap>
<select id="selectAll" resultMap="peopleMap">
select *
from t_people t1
left join t_passport t2 on t1.people_id = t2.people_id
</select>
</mapper>
重点在于resultMap里的写法:
association 标签用于一对一关系:
propetry 后写属性名javaType 后写该属性所属类的类型编写测试类:
public static void main(String[] args) {
SqlSession sqlSession = MybatisUtil.getSqlSession();
PeopleMapper mapper = sqlSession.getMapper(PeopleMapper.class);
mapper.selectAll().forEach(System.out::println);
MybatisUtil.closeSqlSession(sqlSession);
}
这段代码:
mapper.selectAll().forEach(System.out::println);中的写法是在JDK1.8之后有的:
- 格式:集合.foreach(打印方法)
运行结果:

有如下两张表格,t_user(用户),t_order(订单):


用户可以下多个订单,一个订单对应一个用户,这就是一种一对多关系。
查询用户及其所有订单信息:
// Order
public class Order {
private Integer orderId;
private String orderName;
}
// User
public class User {
private Integer uId;
private String userName;
private String userPwd;
private List<Order> orders;
}
xml文件的写法:
<mapper namespace="com.qj.mapper.UserMapper">
<resultMap id="userMap" type="User">
<id property="uId" column="u_id"/>
<result property="userName" column="u_username"/>
<result property="userPwd" column="u_pwd"/>
<collection property="orders" javaType="java.util.List" ofType="Order">
<id property="orderId" column="order_id"/>
<result property="orderName" column="order_name"/>
</collection>
</resultMap>
<select id="selectAll" resultMap="userMap">
select *
from t_user t1
left join t_order t2
on t1.u_id = t2.user_id
</select>
</mapper>
这里与一对一的区别就在于使用的标签不同:
collection 标签:
property后写属性名javaType后写集合类型ofType后写泛型的类型测试结果:

有以下三张表格,表示了学生的选课情况:



一个学生可以选多个课程,而一个课程可以被多个学生选择,这就是典型的多对多关系。
而 多对多 与 一对多 关系在xml文件中resultMap的写法几乎一致,因此不做过多解释,看一下sql 语句与测试结果即可:
<select id="selectAll" resultMap="stuMap">
select *
from t_stu t1
left join t_sc t2 on t1.stu_id = t2.s_id
left join t_course t3 on t3.course_id = t2.c_id
</select>

下篇总结 mybatis 动态sql、常用的标签以及缓存的有关知识,需要的小伙伴记得订阅专栏。
我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.
我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
我的问题的一个例子是体育游戏。一场体育比赛有两支球队,一支主队和一支客队。我的事件记录模型如下:classTeam"Team"has_one:away_team,:class_name=>"Team"end我希望能够通过游戏访问一个团队,例如:Game.find(1).home_team但我收到一个单元化常量错误:Game::team。谁能告诉我我做错了什么?谢谢, 最佳答案 如果Gamehas_one:team那么Rails假设您的teams表有一个game_id列。不过,您想要的是games表有一个team_id列,在这种情况下
前言一般来说,前端根据后台返回code码展示对应内容只需要在前台判断code值展示对应的内容即可,但要是匹配的code码比较多或者多个页面用到时,为了便于后期维护,后台就会使用字典表让前端匹配,下面我将在微信小程序中通过wxs的方法实现这个操作。为什么要使用wxs?{{method(a,b)}}可以看到,上述代码是一个调用方法传值的操作,在vue中很常见,多用于数据之间的转换,但由于微信小程序诸多限制的原因,你并不能优雅的这样操作,可能有人会说,为什么不用if判断实现呢?但是if判断的局限性在于如果存在数据量过大时,大量重复性操作和if判断会让你的代码显得异常冗余。wxswxs相当于是一个独立
📢博客主页:https://blog.csdn.net/weixin_43197380📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正!📢本文由Loewen丶原创,首发于CSDN,转载注明出处🙉📢现在的付出,都会是一种沉淀,只为让你成为更好的人✨文章预览:一.分辨率(Resolution)1、工业相机的分辨率是如何定义的?2、工业相机的分辨率是如何选择的?二.精度(Accuracy)1、像素精度(PixelAccuracy)2、定位精度和重复定位精度(RepeatPrecision)三.公差(Tolerance)四.课后作业(Post-ClassExercises)视觉行业的初学者,甚至是做了1~2年
我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时
require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame
考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://