成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

解析Mybatis對sql表的一對多查詢問題

瀏覽:211日期:2023-03-06 14:25:17

Mybatisd對sql表的一對多查詢

select * fromprojectrecord prleft join projects poon po.pid=pr.pidleft join emp eon e.empno = pr.empnowhere pr.pid=1

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.msb.mapper.EmpMapper">    <!--resultMap是一個映射表,對應的字段會對應數據表的字段    -->    <resultMap id="projectMap" type="projects"><id column="pid" property="pid"></id><result column="pname" property="pname"></result><result column="money" property="money"></result><collection property="projectrecordList" ofType="projectrecord">    <id property="pid" column="pid"></id>    <id property="empno" column="empno"></id>    <association property="emp" javaType="emp"><id property="empno" column="empno"></id><result property="ename" column="ename"></result><result property="job" column="job"></result><result property="sal" column="sal"></result><result property="hiredate" column="hiredate"></result><result property="mgr" column="mgr"></result><result property="comm" column="comm"></result><result property="deptno" column="deptno"></result>    </association></collection>    </resultMap>    <!--Projects findPiddle(int pid);-->    <select id="findPiddle" resultMap="projectMap">select *from    emp einner join    projectrecord pr    on pr.empno=e.empnoinner join    projects po    on po.pid= pr.pidwhere pr.pid=#{pid}    </select></mapper>
//mapper表package com.msb.mapper;import com.msb.pojo.Dept;import com.msb.pojo.Emp;import com.msb.pojo.Projects;import java.util.List;public interface EmpMapper {    /**     * 實現根據項目編號查看所有參與項目的人員信息     * @param pid 傳入項目號     * @return 返回一個project的對象     */    Projects findPiddle(int pid);}
package com.msb.pojo;//一對一關系引入import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import java.io.Serializable;@Data@AllArgsConstructor@NoArgsConstructorpublic class Projectrecord implements Serializable {    private int empno;    private int pid;    //pr和e是一對一的關系    private Emp emp;}
package com.msb.pojo;//一對多關系實體類設計import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import java.io.Serializable;import java.util.List;@NoArgsConstructor@AllArgsConstructor@Datapublic class Projects implements Serializable {    private int pid;    private String pname;    private int money;    //po和pr是一對多的關系    List<Projectrecord> projectrecordList;}
package com.msb.pojo;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import java.sql.Date;@Data@AllArgsConstructor@NoArgsConstructorpublic class Emp {    private Integer empno;    private String ename;    private String job;    private Integer mgr;    private Date hiredate;    private  Integer sal;    private Integer comm;    private  Integer deptno;    private Dept dept;}
jdbc_driver=com.mysql.cj.jdbc.Driverjdbc_url=jdbc:mysql://127.0.0.1:3306/testtable?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghaijdbc_username=rootjdbc_password=root
log4j.rootLogger=debug,stdoutlog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.errlog4j.appender.stdout.layout=org.apache.log4j.SimpleLayoutlog4j.appender.logfile=org.apache.log4j.FileAppenderlog4j.appender.logfile.File=d:/msb.loglog4j.appender.logfile.layout=org.apache.log4j.PatternLayoutlog4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %l %F %p %m%n
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>    <!--引入外部配置文件-->    <properties resource="jdbc.properties"></properties>    <!--這里是起的別名,前面是名,后面是路徑-->    <!--<typeAliases><typeAlias alias="dept" type="com.msb.pojo.Dept"/>    </typeAliases>-->    <!--包別名,用到時候調用名字小寫即可,就會掃描msb下的所以實體類,用的時候實體類名小寫-->    <typeAliases><package name="com.msb"/>    </typeAliases>    <environments default="development"><environment id="development">    <!--   簡單使用了 JDBC 的提交和回滾設置  -->    <transactionManager type="JDBC"/>    <dataSource type="POOLED"><property name="driver" value="${jdbc_driver}"/><property name="url" value="${jdbc_url}"/><property name="username" value="${jdbc_username}"/><property name="password" value="${jdbc_password}"/>    </dataSource></environment>    </environments>    <!--加載mapper映射文件-->    <mappers><package name="com.msb.mapper"/>    </mappers></configuration>
import com.msb.mapper.EmpMapper;import com.msb.pojo.Dept;import com.msb.pojo.Emp;import com.msb.pojo.Projectrecord;import com.msb.pojo.Projects;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 org.junit.After;import org.junit.Before;import org.junit.Test;import java.io.IOException;import java.io.InputStream;import java.util.List;public class Test1 {    SqlSession sqlSession = null;    EmpMapper mapper =null;   @Before   public void test1(){       //首先做一個對象SqlSessionFactoryBuilder建立一個繪話       SqlSessionFactoryBuilder ssfb = new SqlSessionFactoryBuilder();       //有一個文本輸入的io流進行讀取操作       InputStream stream = null;       try {   //這里的路徑直接會定位到配置文件classes下面;所以這個文件在次目錄下--編譯和   //-圖紙;對數據庫文件進行讀取,獲取一個io流,由于配置文件在classes下面,直接寫文件名即可   stream = Resources.getResourceAsStream("sqlMapConfig.xml");       } catch (IOException e) {   e.printStackTrace();       }       //build需要指向一個文件進行讀取出來--工廠       SqlSessionFactory factory = ssfb.build(stream);//需要用sqlSession去調用增刪改查--工人去獲取數據,打開這個繪話       sqlSession = factory.openSession();   }        /*多對多的查詢*/    @Test    public void test7(){mapper = sqlSession.getMapper(EmpMapper.class);Projects piddle = mapper.findPiddle(1);System.out.println("Pid");System.out.println(piddle.getPid());System.out.println("Pname");System.out.println(piddle.getPname());System.out.println("Money");System.out.println(piddle.getMoney());System.out.println("ProjectrecordList");List<Projectrecord> projectrecordList = piddle.getProjectrecordList();projectrecordList.forEach(System.out::println);    }        @After    public void test3(){       if (sqlSession!=null){   sqlSession.close();       }    }}

到此這篇關于解析Mybatis對sql表的一對多查詢的文章就介紹到這了,更多相關Mybatis一對多查詢內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲老妇xxxxxx| 最新亚洲一区| 亚洲国产精品视频一区| 欧美精品一区二区三区在线| 久久精品99国产国产精| 91福利视频网站| 男人的天堂久久精品| 色素色在线综合| 美女mm1313爽爽久久久蜜臀| 欧美日韩一区二区三区高清 | 高清不卡一区二区| 日韩一区二区三区免费观看| 成人午夜伦理影院| 欧美mv日韩mv| 91网站最新地址| 中文字幕电影一区| 亚洲国产精品久久久久久女王| 亚洲欧洲日韩在线| 中国成人在线视频| 午夜精品国产更新| 欧美亚洲禁片免费| 国产成人精品影视| 久久免费视频色| 精品动漫一区| 亚洲www啪成人一区二区麻豆| 欧美亚洲国产bt| 懂色av中文字幕一区二区三区| 久久伊人蜜桃av一区二区| 91视频www| 亚洲视频免费观看| 久久精品日产第一区二区三区| 免费观看日韩电影| 欧美一区二区三区在线看| 99久久伊人久久99| 中文字幕av一区二区三区高| 日韩午夜黄色| 日本不卡高清视频| 欧美大片免费久久精品三p | 欧美精品第一页| 成人av网站免费观看| 国产精品女同一区二区三区| 一区二区高清视频| 日韩成人一区二区三区在线观看| 欧美在线看片a免费观看| 国产激情偷乱视频一区二区三区| 久久久久国产精品人| 亚洲国产日韩在线| 日韩激情视频网站| 91精品国产品国语在线不卡| 欧美成人日本| 亚洲一卡二卡三卡四卡五卡| 欧美视频在线一区二区三区 | 欧美日本一道本在线视频| 国产成人精品一区二区三区四区| 久久嫩草精品久久久久| 亚洲国产婷婷| 蜜桃视频在线一区| 精品国产制服丝袜高跟| 91久久精品国产91久久性色tv | 欧美一区1区三区3区公司| 亚洲免费资源在线播放| 久久综合一区| 国产高清成人在线| 欧美高清在线精品一区| 亚洲影音一区| 国产91精品一区二区麻豆网站| 一区二区中文字幕在线| 欧美午夜精品电影| 女女同性精品视频| 婷婷国产v国产偷v亚洲高清| 欧美电影免费观看高清完整版在| 亚洲激情视频| 国产乱码精品一品二品| 中文字幕亚洲一区二区av在线| 在线日韩国产精品| 欧美一区免费视频| 午夜电影一区二区| 国产亚洲欧美色| 一本色道久久加勒比精品| 国产91丝袜在线播放| 亚洲精品成a人| 欧美一级在线免费| 一区二区三区四区国产| 国产成人精品亚洲日本在线桃色 | 国内精品久久国产| 日本女优在线视频一区二区| 精品国产一区二区三区久久久蜜月 | 91.xcao| 亚洲国产成人不卡| 国内精品不卡在线| 亚洲伦理在线精品| 日韩女优av电影在线观看| 在线亚洲国产精品网站| 国产成人午夜片在线观看高清观看| 亚洲乱码日产精品bd| 日韩一区二区在线观看视频播放| 99亚洲一区二区| 成人白浆超碰人人人人| 视频一区欧美精品| 欧美国产乱子伦 | 日韩欧美中文字幕制服| 国产亚洲精品v| jizzjizzjizz欧美| 日韩国产欧美视频| 国产精品拍天天在线| 91麻豆精品国产自产在线| 国产欧美日韩一区| 欧美激情aⅴ一区二区三区| 精品一区二区三区久久久| 亚洲欧美日韩中文播放| 精品久久久久久最新网址| 日本高清免费不卡视频| 99视频在线精品国自产拍免费观看| 成人黄色一级视频| 蜜臀久久99精品久久久久久9| 国产精品国产自产拍在线| 欧美一区二区三区免费观看视频 | 中文字幕一区二区三区四区| 欧美精品v日韩精品v韩国精品v| 国产视频一区在线观看一区免费| 99久久99久久免费精品蜜臀| 精品系列免费在线观看| 亚洲黄色尤物视频| 久久久久久**毛片大全| 欧美乱妇15p| 久久亚洲二区| 亚洲精选久久| 91美女精品福利| 国产成人小视频| 久久精品久久综合| 亚洲成人资源在线| 亚洲欧美激情视频在线观看一区二区三区 | 91精品国产综合久久久蜜臀粉嫩| 亚洲一区亚洲| 一区在线观看| 午夜久久美女| a级精品国产片在线观看| 韩国女主播成人在线| 日韩精品91亚洲二区在线观看| 亚洲视频1区2区| 国产婷婷一区二区| 日韩欧美美女一区二区三区| 欧美伊人久久久久久久久影院| 国产精品视频福利| 亚洲小说区图片区| 欧美在线视频二区| 菠萝蜜视频在线观看一区| 国产最新精品免费| 全部av―极品视觉盛宴亚洲| 亚洲风情在线资源站| 依依成人综合视频| 亚洲欧洲综合另类在线| 国产精品久久福利| 国产精品久久久久久久久动漫| 国产亚洲视频系列| 久久久国产精品午夜一区ai换脸| 欧美草草影院在线视频| 日韩视频一区二区三区| 欧美一区二区三区的| 91精品国产欧美一区二区| 欧美疯狂做受xxxx富婆| 欧美精品一卡两卡| 欧美丰满美乳xxx高潮www| 一本久久精品一区二区| 亚洲一区免费| 久久av二区| 久久综合久久久| 可以看av的网站久久看| 一本大道久久a久久综合| 欧美综合77777色婷婷| 久久精品首页| 在线中文字幕一区二区| 91成人网在线| 欧美精品色一区二区三区| 欧美精品乱码久久久久久 | 亚洲第一电影网| 亚洲va国产天堂va久久en| 亚洲午夜视频在线观看| 天天做天天摸天天爽国产一区 | 日韩你懂的在线观看| 日韩精品最新网址| 久久综合色天天久久综合图片| 欧美精品一区二区三区蜜桃| 国产视频在线观看一区二区三区 | 在线影视一区二区三区| 欧美午夜精品理论片a级按摩| 欧洲亚洲精品在线| 7777精品伊人久久久大香线蕉的 | 日本韩国精品一区二区在线观看| 91国内精品野花午夜精品| 欧美三级电影精品| 日韩一级免费观看| 精品处破学生在线二十三| 久久久久久久久久久久久女国产乱 | 欧美一级视频| 欧美性猛交xxxxxx富婆| 欧美一区日韩一区| 国产亚洲欧美日韩日本| 亚洲精品视频免费看| 日韩福利视频网|