MyBatisの(3)MyBatisのマッピング開発

4.1マンツーマン

4.1.1対応関係テーブル

ユーザに対応するため

エンティティ間の4.1.2対応

public class Order {
 private int id; private Date ordertime; private double total; //代表当前订单属于哪个用户 private User user; } public class User { private int id; private String username; private String password; private Date birthday; } 

4.1.3設定ファイルOrderMapper.xml

<mapper namespace="com.lagou.mapper.OrderMapper">
 <resultMap id="orderMap" type="com.lagou.domain.Order"> <result column="uid" property="user.id"></result> <result column="username" property="user.username"></result> <result column="password" property="user.password"></result> <result column="birthday" property="user.birthday"></result> </resultMap> <select id="findAll" resultMap="orderMap"> select * from orders o,user u where o.uid=u.id </select> </mapper> #或者还可以这样配置 <resultMap id="orderMap" type="com.lagou.domain.Order"> <result property="id" column="id"></result> <result property="ordertime" column="ordertime"></result> <result property="total" column="total"></result> <association property="user" javaType="com.lagou.domain.User"> <result column="uid" property="id"></result> <result column="username" property="username"></result> <result column="password" property="password"></result> <result column="birthday" property="birthday"></result> </association> </resultMap> 

4.2対多

間テーブル4.2.1対応

image.png
クエリは次のように記述することができます

*、選択o.id  uは左u.id = o.uidにoを受注に参加するユーザからOIDを。

4.2.2エンティティクラス関係

public class Order {
 private int id; private Date ordertime; private double total; //当前订单属于哪个用户 private User user; } public class User { private int id; private String username; private String password; private Date birthday; //当前用户的订单列表 private List<Order> orderList; } 

4.2.3 UserMapper.xml

<mapper namespace="com.lagou.mapper.UserMapper">
 <resultMap id="userMap" type="com.lagou.domain.User"> <result column="id" property="id"></result> <result column="username" property="username"></result> <result column="password" property="password"></result> <result column="birthday" property="birthday"></result> <collection property="orderList" ofType="com.lagou.domain.Order"> <result column="oid" property="id"></result> <result column="ordertime" property="ordertime"></result> <result column="total" property="total"></result> </collection> </resultMap> <select id="findAll" resultMap="userMap"> select *,o.id oid from user u left join orders o on u.id=o.uid </select> </mapper> 

4.3-多く

間テーブル4.3.1対応

image.png
対応するSQL文

Uを選択します。、R。r.id  ユーザーから取り除くuが参加左USER_ROLEウル上u.id = ur.user_id

インナーはur.role_id =上の役割rの参加r.idを

4.3.2エンティティクラスの対応関係

public class User {
 private int id; private String username; private String password; private Date birthday; //当前用户具备哪些角色 private List<Role> roleList; } public class Role { private int id; private String rolename; } 

4.3.3設定ファイルUserMapper.xml

<resultMap id="userRoleMap" type="com.lagou.domain.User"> <result column="id" property="id"></result> <result column="username" property="username"></result> <result column="password" property="password"></result> <result column="birthday" property="birthday"></result> <collection property="roleList" ofType="com.lagou.domain.Role"> <result column="rid" property="id"></result> <result column="rolename" property="rolename"></result> </collection> </resultMap> <select id="findAllUserAndRole" resultMap="userRoleMap"> select u.*,r.*,r.id rid from user u left join user_role ur on u.id=ur.user_id inner join role r on ur.role_id=r.id </select>




オリジナル:https://www.cnblogs.com/benjaming0321/p/12546839.html

おすすめ

転載: www.cnblogs.com/MonsterJ/p/12561291.html