2020-03-21

1.Mybatis多表查詢

1.1 一對一查詢

1.1.1 一對一查詢的模型

用戶表和訂單表的關(guān)系為横缔,一個用戶有多個訂單,一個訂單只從屬于一個用戶

一對一查詢的需求:查詢一個訂單闯狱,與此同時查詢出該訂單所屬的用戶

1.1.2一對一查詢的語句

對應(yīng)的sql語句:select *? from orders o,user u where o.uid=u.id;

查詢的結(jié)果如下:

1.1.3 創(chuàng)建Order和User實體

publicclassOrder{

?

privateintid;

privateDateordertime;

privatedoubletotal;

?

//代表當(dāng)前訂單從屬于哪一個客戶

privateUseruser;

}

?

publicclassUser{


privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

?

}

1.1.4 創(chuàng)建OrderMapper接口

publicinterfaceOrderMapper{

List<Order>findAll();

}

1.1.5 配置OrderMapper.xml

<mappernamespace="com.itheima.mapper.OrderMapper">

<resultMapid="orderMap"type="com.itheima.domain.Order">

<resultcolumn="uid"property="user.id"></result>

<resultcolumn="username"property="user.username"></result>

<resultcolumn="password"property="user.password"></result>

<resultcolumn="birthday"property="user.birthday"></result>

</resultMap>

<selectid="findAll"resultMap="orderMap">

? ? ?? select * from orders o,user u where o.uid=u.id

</select>

</mapper>

其中<resultMap>還可以配置如下:

<resultMapid="orderMap"type="com.itheima.domain.Order">

<resultproperty="id"column="id"></result>

<resultproperty="ordertime"column="ordertime"></result>

<resultproperty="total"column="total"></result>

<associationproperty="user"javaType="com.itheima.domain.User">

<resultcolumn="uid"property="id"></result>

<resultcolumn="username"property="username"></result>

<resultcolumn="password"property="password"></result>

<resultcolumn="birthday"property="birthday"></result>

</association>

</resultMap>

1.1.6 測試結(jié)果

OrderMappermapper=sqlSession.getMapper(OrderMapper.class);

List<Order>all=mapper.findAll();

for(Orderorder:all){

System.out.println(order);

}

1.2 一對多查詢

1.2.1 一對多查詢的模型

用戶表和訂單表的關(guān)系為,一個用戶有多個訂單,一個訂單只從屬于一個用戶

一對多查詢的需求:查詢一個用戶,與此同時查詢出該用戶具有的訂單


1.2.2 一對多查詢的語句

對應(yīng)的sql語句:select *,o.id oid from user u left join orders o on u.id=o.uid;

查詢的結(jié)果如下:

1.2.3 修改User實體

publicclassOrder{

?

privateintid;

privateDateordertime;

privatedoubletotal;

?

//代表當(dāng)前訂單從屬于哪一個客戶

privateUseruser;

}

?

publicclassUser{


privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

//代表當(dāng)前用戶具備哪些訂單

privateList<Order>orderList;

}

?

1.2.4 創(chuàng)建UserMapper接口

publicinterfaceUserMapper{

List<User>findAll();

}

?

1.2.5 配置UserMapper.xml

<mappernamespace="com.itheima.mapper.UserMapper">

<resultMapid="userMap"type="com.itheima.domain.User">

<resultcolumn="id"property="id"></result>

<resultcolumn="username"property="username"></result>

<resultcolumn="password"property="password"></result>

<resultcolumn="birthday"property="birthday"></result>

<collectionproperty="orderList"ofType="com.itheima.domain.Order">

<resultcolumn="oid"property="id"></result>

<resultcolumn="ordertime"property="ordertime"></result>

<resultcolumn="total"property="total"></result>

</collection>

</resultMap>

<selectid="findAll"resultMap="userMap">

? ? ?? select *,o.id oid from user u left join orders o on u.id=o.uid

</select>

</mapper>

1.2.6 測試結(jié)果

UserMappermapper=sqlSession.getMapper(UserMapper.class);

List<User>all=mapper.findAll();

for(Useruser:all){

System.out.println(user.getUsername());

List<Order>orderList=user.getOrderList();

for(Orderorder:orderList){

System.out.println(order);

?? }

System.out.println("----------------------------------");

}

1.3 多對多查詢

1.3.1 多對多查詢的模型

用戶表和角色表的關(guān)系為瓮具,一個用戶有多個角色,一個角色被多個用戶使用

多對多查詢的需求:查詢用戶同時查詢出該用戶的所有角色

1.3.2 多對多查詢的語句

對應(yīng)的sql語句: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;

查詢的結(jié)果如下:

1.3.3 創(chuàng)建Role實體凡人,修改User實體

publicclassUser{

privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

//代表當(dāng)前用戶具備哪些訂單

privateList<Order>orderList;

//代表當(dāng)前用戶具備哪些角色

privateList<Role>roleList;

}

?

publicclassRole{

?

privateintid;

privateStringrolename;

?

}

?

1.3.4? 添加UserMapper接口方法

List<User>findAllUserAndRole();

1.3.5 配置UserMapper.xml

<resultMapid="userRoleMap"type="com.itheima.domain.User">

<resultcolumn="id"property="id"></result>

<resultcolumn="username"property="username"></result>

<resultcolumn="password"property="password"></result>

<resultcolumn="birthday"property="birthday"></result>

<collectionproperty="roleList"ofType="com.itheima.domain.Role">

<resultcolumn="rid"property="id"></result>

<resultcolumn="rolename"property="rolename"></result>

</collection>

</resultMap>

<selectid="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>

1.3.6 測試結(jié)果

UserMappermapper=sqlSession.getMapper(UserMapper.class);

List<User>all=mapper.findAllUserAndRole();

for(Useruser:all){

System.out.println(user.getUsername());

List<Role>roleList=user.getRoleList();

for(Rolerole:roleList){

System.out.println(role);

?? }

System.out.println("----------------------------------");

}

1.4 知識小結(jié)

MyBatis多表配置方式:

一對一配置:使用<resultMap>做配置

一對多配置:使用<resultMap>+<collection>做配置

多對多配置:使用<resultMap>+<collection>做配置

2.Mybatis的注解開發(fā)

2.1 MyBatis的常用注解

這幾年來注解開發(fā)越來越流行名党,Mybatis也可以使用注解開發(fā)方式,這樣我們就可以減少編寫Mapper

映射文件了挠轴。我們先圍繞一些基本的CRUD來學(xué)習(xí)传睹,再學(xué)習(xí)復(fù)雜映射多表操作。

@Insert:實現(xiàn)新增

@Update:實現(xiàn)更新

@Delete:實現(xiàn)刪除

@Select:實現(xiàn)查詢

@Result:實現(xiàn)結(jié)果集封裝

@Results:可以與@Result 一起使用岸晦,封裝多個結(jié)果集

@One:實現(xiàn)一對一結(jié)果集封裝

@Many:實現(xiàn)一對多結(jié)果集封裝

2.2 MyBatis的增刪改查

我們完成簡單的user表的增刪改查的操作

privateUserMapperuserMapper;

?

@Before

publicvoidbefore()throwsIOException{

InputStreamresourceAsStream=Resources.getResourceAsStream("SqlMapConfig.xml");

SqlSessionFactorysqlSessionFactory=new

SqlSessionFactoryBuilder().build(resourceAsStream);

SqlSessionsqlSession=sqlSessionFactory.openSession(true);

userMapper=sqlSession.getMapper(UserMapper.class);

}

?

@Test

publicvoidtestAdd() {

Useruser=newUser();

user.setUsername("測試數(shù)據(jù)");

user.setPassword("123");

user.setBirthday(newDate());

userMapper.add(user);

}

@Test

publicvoidtestUpdate()throwsIOException{

Useruser=newUser();

user.setId(16);

user.setUsername("測試數(shù)據(jù)修改");

user.setPassword("abc");

user.setBirthday(newDate());

userMapper.update(user);

}

?

@Test

publicvoidtestDelete()throwsIOException{

userMapper.delete(16);

}

@Test

publicvoidtestFindById()throwsIOException{

Useruser=userMapper.findById(1);

System.out.println(user);

}

@Test

publicvoidtestFindAll()throwsIOException{

List<User>all=userMapper.findAll();

for(Useruser:all){

System.out.println(user);

?? }

}

?

修改MyBatis的核心配置文件欧啤,我們使用了注解替代的映射文件睛藻,所以我們只需要加載使用了注解的Mapper接口即可

<mappers>

<!--掃描使用注解的類-->

<mapperclass="com.itheima.mapper.UserMapper"></mapper>

</mappers>

或者指定掃描包含映射關(guān)系的接口所在的包也可以

<mappers>

<!--掃描使用注解的類所在的包-->

<packagename="com.itheima.mapper"></package>

</mappers>

2.3 MyBatis的注解實現(xiàn)復(fù)雜映射開發(fā)

實現(xiàn)復(fù)雜關(guān)系映射之前我們可以在映射文件中通過配置<resultMap>來實現(xiàn),使用注解開發(fā)后邢隧,我們可以使用@Results注解店印,@Result注解,@One注解倒慧,@Many注解組合完成復(fù)雜關(guān)系的配置

2.4 一對一查詢

2.4.1 一對一查詢的模型

用戶表和訂單表的關(guān)系為按摘,一個用戶有多個訂單,一個訂單只從屬于一個用戶

一對一查詢的需求:查詢一個訂單纫谅,與此同時查詢出該訂單所屬的用戶

2.4.2 一對一查詢的語句

對應(yīng)的sql語句:

select * from orders;

?

select * from user where id=查詢出訂單的uid;

查詢的結(jié)果如下:

2.4.3 創(chuàng)建Order和User實體

publicclassOrder{

?

privateintid;

privateDateordertime;

privatedoubletotal;

?

//代表當(dāng)前訂單從屬于哪一個客戶

privateUseruser;

}

?

publicclassUser{


privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

?

}

2.4.4 創(chuàng)建OrderMapper接口

publicinterfaceOrderMapper{

List<Order>findAll();

}

2.4.5 使用注解配置Mapper

publicinterfaceOrderMapper{

@Select("select * from orders")

@Results({

@Result(id=true,property="id",column="id"),

@Result(property="ordertime",column="ordertime"),

@Result(property="total",column="total"),

@Result(property="user",column="uid",

javaType=User.class,

one=@One(select="com.itheima.mapper.UserMapper.findById"))

?? })

List<Order>findAll();

}

publicinterfaceUserMapper{

?

@Select("select * from user where id=#{id}")

UserfindById(intid);


}

2.4.6 測試結(jié)果

@Test

publicvoidtestSelectOrderAndUser() {

List<Order>all=orderMapper.findAll();

for(Orderorder:all){

System.out.println(order);

?? }

}

2.5 一對多查詢

2.5.1 一對多查詢的模型

用戶表和訂單表的關(guān)系為炫贤,一個用戶有多個訂單,一個訂單只從屬于一個用戶

一對多查詢的需求:查詢一個用戶付秕,與此同時查詢出該用戶具有的訂單

2.5.2 一對多查詢的語句

對應(yīng)的sql語句:

select * from user;

?

select * from orders where uid=查詢出用戶的id;

查詢的結(jié)果如下:

2.5.3 修改User實體

publicclassOrder{

?

privateintid;

privateDateordertime;

privatedoubletotal;

?

//代表當(dāng)前訂單從屬于哪一個客戶

privateUseruser;

}

?

publicclassUser{


privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

//代表當(dāng)前用戶具備哪些訂單

privateList<Order>orderList;

}

2.5.4 創(chuàng)建UserMapper接口

List<User>findAllUserAndOrder();

2.5.5 使用注解配置Mapper

publicinterfaceUserMapper{

@Select("select * from user")

@Results({

@Result(id=true,property="id",column="id"),

@Result(property="username",column="username"),

@Result(property="password",column="password"),

@Result(property="birthday",column="birthday"),

@Result(property="orderList",column="id",

javaType=List.class,

many=@Many(select="com.itheima.mapper.OrderMapper.findByUid"))

?? })

List<User>findAllUserAndOrder();

}

?

publicinterfaceOrderMapper{

@Select("select * from orders where uid=#{uid}")

List<Order>findByUid(intuid);

?

}

2.5.6 測試結(jié)果

List<User>all=userMapper.findAllUserAndOrder();

for(Useruser:all){

System.out.println(user.getUsername());

List<Order>orderList=user.getOrderList();

for(Orderorder:orderList){

System.out.println(order);

?? }

System.out.println("-----------------------------");

}

2.6 多對多查詢

2.6.1 多對多查詢的模型

用戶表和角色表的關(guān)系為兰珍,一個用戶有多個角色,一個角色被多個用戶使用

多對多查詢的需求:查詢用戶同時查詢出該用戶的所有角色

2.6.2 多對多查詢的語句

對應(yīng)的sql語句:

select * from user;

?

select * from role r,user_role ur where r.id=ur.role_id and ur.user_id=用戶的id

查詢的結(jié)果如下:

2.6.3 創(chuàng)建Role實體询吴,修改User實體

publicclassUser{

privateintid;

privateStringusername;

privateStringpassword;

privateDatebirthday;

//代表當(dāng)前用戶具備哪些訂單

privateList<Order>orderList;

//代表當(dāng)前用戶具備哪些角色

privateList<Role>roleList;

}

?

publicclassRole{

?

privateintid;

privateStringrolename;

?

}

2.6.4 添加UserMapper接口方法

List<User>findAllUserAndRole();

2.6.5 使用注解配置Mapper

publicinterfaceUserMapper{

@Select("select * from user")

@Results({

@Result(id=true,property="id",column="id"),

@Result(property="username",column="username"),

@Result(property="password",column="password"),

@Result(property="birthday",column="birthday"),

@Result(property="roleList",column="id",

javaType=List.class,

many=@Many(select="com.itheima.mapper.RoleMapper.findByUid"))

})

List<User>findAllUserAndRole();}

?

?

?

publicinterfaceRoleMapper{

@Select("select * from role r,user_role ur where r.id=ur.role_id and ur.user_id=#{uid}")

List<Role>findByUid(intuid);

}

?

2.6.6 測試結(jié)果

UserMappermapper=sqlSession.getMapper(UserMapper.class);

List<User>all=mapper.findAllUserAndRole();

for(Useruser:all){

System.out.println(user.getUsername());

List<Role>roleList=user.getRoleList();

for(Rolerole:roleList){

System.out.println(role);

?? }

System.out.println("----------------------------------");

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末掠河,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子汰寓,更是在濱河造成了極大的恐慌口柳,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件有滑,死亡現(xiàn)場離奇詭異跃闹,居然都是意外死亡,警方通過查閱死者的電腦和手機毛好,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門望艺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人肌访,你說我怎么就攤上這事找默。” “怎么了吼驶?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵惩激,是天一觀的道長。 經(jīng)常有香客問我蟹演,道長风钻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任酒请,我火速辦了婚禮骡技,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己布朦,他們只是感情好囤萤,可當(dāng)我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著是趴,像睡著了一般涛舍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上右遭,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天做盅,我揣著相機與錄音,去河邊找鬼窘哈。 笑死,一個胖子當(dāng)著我的面吹牛亭敢,可吹牛的內(nèi)容都是我干的滚婉。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼帅刀,長吁一口氣:“原來是場噩夢啊……” “哼让腹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起扣溺,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤骇窍,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后锥余,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腹纳,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年驱犹,在試婚紗的時候發(fā)現(xiàn)自己被綠了嘲恍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡雄驹,死狀恐怖佃牛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情医舆,我是刑警寧澤俘侠,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站蔬将,受9級特大地震影響爷速,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜娃胆,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一遍希、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧里烦,春花似錦凿蒜、人聲如沸禁谦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽州泊。三九已至,卻和暖如春漂洋,著一層夾襖步出監(jiān)牢的瞬間遥皂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工刽漂, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留演训,地道東北人。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓贝咙,卻偏偏與公主長得像样悟,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子庭猩,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內(nèi)容

  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,446評論 0 13
  • 轉(zhuǎn)載窟她,覺得這篇寫 SQLAlchemy Core,寫得非常不錯蔼水。不過后續(xù)他沒寫SQLAlchemy ORM... ...
    非夢nj閱讀 5,372評論 1 14
  • 一震糖、引言 通過動態(tài)SQL我們可以進(jìn)行復(fù)雜SQL的編寫,但之前的例子都是單表查詢趴腋,在實際開發(fā)中吊说,當(dāng)然不可能都是單表,...
    零點145閱讀 266評論 0 0
  • wyun_guest需要添加的地方 1: oauth_clients需要添加一條記錄image.png INSER...
    EddieZhang閱讀 665評論 0 0
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,790評論 0 11