电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java工程mybatis實現多表查詢過程詳解

瀏覽:5日期:2022-08-30 14:47:33

1、先做一些準備工作

我們首先在創建一個 java 工程,還需要創建兩張表,它們分別是用戶表 user,和帖子表 post,一個戶用戶可以有多個帖子。user表的結構和數據:

-- ------------------------------ Table structure for `user`-- ----------------------------CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `username` varchar(64) NOT NULL DEFAULT ’’, `mobile` int(10) unsigned NOT NULL DEFAULT ’0’, `created` datetime NOT NULL DEFAULT ’0000-00-00 00:00:00’, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; -- ------------------------------ Records of user-- ----------------------------INSERT INTO `user` VALUES (’1’, ’yiibai’, ’100’, ’2015-09-23 20:11:23’);

帖子表 post 的結構和數據:

-- ------------------------------ Table structure for `post`-- ----------------------------CREATE TABLE `post` ( `post_id` int(10) unsigned NOT NULL AUTO_INCREMENT, `userid` int(10) unsigned NOT NULL, `title` varchar(254) NOT NULL DEFAULT ’’, `content` text, `created` datetime NOT NULL DEFAULT ’0000-00-00 00:00:00’, PRIMARY KEY (`post_id`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;-- ------------------------------ Records of post-- ----------------------------INSERT INTO `post` VALUES (’1’, ’1’, ’MyBatis關聯數據查詢’, ’在實際項目中,經常使用關聯表的查詢,比如:多對一,一對多等。這些查詢是如何處理的呢,這一講就講這個問題。我們首先創建一個 post 表,并初始化數據.’, ’2015-09-23 21:40:17’);INSERT INTO `post` VALUES (’2’, ’1’, ’MyBatis開發環境搭建’, ’為了方便學習,這里直接建立java 工程,但一般都是開發 Web 項目。’, ’2015-09-23 21:42:14’);INSERT INTO `post` VALUES (’3’, ’2’, ’這個是別人發的’, ’content,內容...’, ’0000-00-00 00:00:00’);

從上面應該看出,這幾個帖子對應的 userid 都是1,所以需要用戶表 user 里面有 id=1 的數據。可以修改成滿足自己條件的數據,按照orm的規則,表肯定需要一個對象與之對應,所以我們增加一個 Post 類。

2、創建表對應的 JavaBean 對象

這個例子中,我們需要在包 com.yiibai.pojo 下創建兩個類,它們分別是: User.java 和 Post.java,我們一個一個地來看它們的代碼,User.java 類的代碼如下:

package com.yiibai.pojo;import java.io.Serializable;import java.util.Date;import java.util.List;public class User implements Serializable{ private int id; private String username; private String mobile; private List<Post> posts; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getMobile() { return mobile; } public void setMobile(String mobile) { this.mobile = mobile; } public List<Post> getPosts() { return posts; } public void setPosts(List<Post> posts) { this.posts = posts; } @Override public String toString() { return 'User [id=' + id + ', name=' + username + ']'; }}

package com.yiibai.pojo; import java.io.Serializable; public class Post implements Serializable{ private int id; private User user; private String title; private String content; public int getId() { return id; } public void setId(int id) { this.id = id; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getContent() { return content; } public void setContent(String content) { this.content = content; }}

3、配置文件

在這一章節中,要用到的配置文件有兩個,一個是 mybatis 的主配置文件:src/config/Configure.xml 和 User.java對應的配置文件 User.xml,我們先來看看 src/config/Configure.xml,其詳細配置信息如下:

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE configuration PUBLIC '-//mybatis.org//DTD Config 3.0//EN''http://mybatis.org/dtd/mybatis-3-config.dtd'><configuration> <typeAliases> <typeAlias alias='User' type='com.yiibai.pojo.User' /> <typeAlias alias='Post' type='com.yiibai.pojo.Post' /> </typeAliases> <environments default='development'> <environment id='development'> <transactionManager type='JDBC' /> <dataSource type='POOLED'><property name='driver' value='com.mysql.jdbc.Driver' /><property name='url' value='jdbc:mysql://127.0.0.1:3306/yiibai' /><property name='username' value='root' /><property name='password' value='' /> </dataSource> </environment> </environments> <mappers> <!-- // power by http://www.yiibai.com --> <mapper resource='com/yiibai/pojo/User.xml' /> </mappers></configuration>

用于定義一個 JavaBean 類的別名,如將 com.yiibai.pojo.User 簡寫為 User,可以認為 com.yiibai.pojo.User 就是 User,User 就是 com.yiibai.pojo.User 。

另外一個配置文件 User.xml 的內容如下:

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.yiibai.userMaper'> <!-- User 級聯文章查詢 方法配置 (一個用戶對多個文章) --> <resultMap type='User' id='resultUserMap'> <result property='id' column='user_id' /> <result property='username' column='username' /> <result property='mobile' column='mobile' /> <collection property='posts' ofType='com.yiibai.pojo.Post' column='userid'> <id property='id' column='post_id' javaType='int' jdbcType='INTEGER'/><result property='title' column='title' javaType='string' jdbcType='VARCHAR'/> <result property='content' column='content' javaType='string' jdbcType='VARCHAR'/> </collection> </resultMap> <select resultMap='resultUserMap' parameterType='int'> SELECT u.*,p.* FROM user u, post p WHERE u.id=p.userid AND id=#{user_id} </select></mapper>

4、測試程序運行

到這里,整個工作準備得已經差不多了,我們創建一個主類來測試上面程序,在 src 下創建一個 Main.java,代碼如下:

import java.io.Reader;import java.text.MessageFormat;import java.util.List; import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder; import com.yiibai.pojo.Post;import com.yiibai.pojo.User; public class Main { private static SqlSessionFactory sqlSessionFactory; private static Reader reader; static { try { reader = Resources.getResourceAsReader('config/Configure.xml'); sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); } catch (Exception e) { e.printStackTrace(); } } public static SqlSessionFactory getSession() { return sqlSessionFactory; } /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub SqlSession session = sqlSessionFactory.openSession(); try { int userid = 1; User user = session.selectOne('com.yiibai.userMaper.getUser', 1); System.out.println('username: '+user.getUsername()+','); List<Post> posts = user.getPosts(); for(Post p : posts) { System.out.println('Title:' + p.getTitle()); System.out.println('Content:' + p.getContent()); } } finally { session.close(); } } }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 屏蔽服(500kv-超高压-特高压-电磁)-徐吉电气 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 破碎机锤头_合金耐磨锤头_郑州宇耐机械工程技术有限公司 | 地磅-电子地磅维修-电子吊秤-汽车衡-无人值守系统-公路治超-鹰牌衡器 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 食药成分检测_调料配方还原_洗涤剂化学成分分析_饲料_百检信息科技有限公司 | 联系我们老街华纳娱乐公司官网19989979996(客服) | T恤衫定做,企业文化衫制作订做,广告T恤POLO衫定制厂家[源头工厂]-【汉诚T恤定制网】 | 特材真空腔体_哈氏合金/镍基合金/纯镍腔体-无锡国德机械制造有限公司 | 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | 琉璃瓦-琉璃瓦厂家-安徽盛阳新型建材科技有限公司 | 洛阳防爆合格证办理-洛阳防爆认证机构-洛阳申请国家防爆合格证-洛阳本安防爆认证代办-洛阳沪南抚防爆电气技术服务有限公司 | 福建成考网-福建成人高考网| 江西自考网-江西自学考试网| 压装机-卧式轴承轮轴数控伺服压装机厂家[铭泽机械] | 天长市晶耀仪表有限公司| LINK FASHION 童装·青少年装展 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 亿立分板机_曲线_锯片式_走刀_在线式全自动_铣刀_在线V槽分板机-杭州亿协智能装备有限公司 | 强效碱性清洗剂-实验室中性清洗剂-食品级高纯氮气发生器-上海润榕科学器材有限公司 | 冲击式破碎机-冲击式制砂机-移动碎石机厂家_青州市富康机械有限公司 | LZ-373测厚仪-华瑞VOC气体检测仪-个人有毒气体检测仪-厂家-深圳市深博瑞仪器仪表有限公司 | 昆山新莱洁净应用材料股份有限公司-卫生级蝶阀,无菌取样阀,不锈钢隔膜阀,换向阀,离心泵 | 自动化生产线-自动化装配线-直流电机自动化生产线-东莞市慧百自动化有限公司 | 三佳互联一站式网站建设服务|网站开发|网站设计|网站搭建服务商 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 微信小程序定制,广州app公众号商城网站开发公司-广东锋火 | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | ptc_浴霸_大巴_干衣机_呼吸机_毛巾架_电动车加热器-上海帕克 | 精密模具加工制造 - 富东懿| 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 高尔夫球杆_高尔夫果岭_高尔夫用品-深圳市新高品体育用品有限公司 | 粘度计,数显粘度计,指针旋转粘度计 | 无锡不干胶标签,卷筒标签,无锡瑞彩包装材料有限公司 | 无轨电动平车_轨道平车_蓄电池电动平车★尽在新乡百特智能转运设备有限公司 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 磁力加热搅拌器-多工位|大功率|数显恒温磁力搅拌器-司乐仪器官网 | 桁架楼承板-钢筋桁架楼承板-江苏众力达钢筋楼承板厂 | TPE塑胶原料-PPA|杜邦pom工程塑料、PPSU|PCTG材料、PC/PBT价格-悦诚塑胶 | 气动隔膜阀_气动隔膜阀厂家_卫生级隔膜阀价格_浙江浙控阀门有限公司 | 办公室家具公司_办公家具品牌厂家_森拉堡办公家具【官网】 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 |