按照嵌套查询方式进行一对多查询
我的方法:在配置文件中写出一对多查询的sql语句
先看看数据表结构,假设在一个论坛问答网站有两个表,一个是用户表,一个是问题表,现在需要查询出id为1的用户写了哪些问题
问题表:
data:image/s3,"s3://crabby-images/a8300/a83003311921b4b9fe3157789e2e2bdc834233a1" alt=""
用户表:
data:image/s3,"s3://crabby-images/420d9/420d957e305f4e88150ac6197c83384b0daf5dcc" alt=""
SQL语句:SELECT*from questions where questions.user_id=1
查询结果:
data:image/s3,"s3://crabby-images/dbe02/dbe0299922c397fbbb6216973b295683f0b97f76" alt=""
先创建POJO类
对照数据表,创建Question类
data:image/s3,"s3://crabby-images/fa3a7/fa3a7c685d228b7cd22e291fb2c1924043304993" alt=""
对照数据表,创建User类
data:image/s3,"s3://crabby-images/75edd/75edde52835f7577618e9f07f0b09d4fb90492eb" alt=""
(Getter和Setter方法自己写)
写出配置文件,将SQL语句卸载配置文件中,这里的输入参数我用的是int,返回类型是Question
QuestionMapper.xml
data:image/s3,"s3://crabby-images/7792f/7792fdb7021ae2898d670adc4e5afff2c21a6fe1" alt=""
data:image/s3,"s3://crabby-images/ac9d7/ac9d707c38f99d6aab5310eab865e84c9eda5ae0" alt=""
在总的配置文件中注册刚才的Mapper
写出测试方法
data:image/s3,"s3://crabby-images/68f3e/68f3e4e32cb73c6e61c2caf61de9662010eb734c" alt=""
运行结果:
data:image/s3,"s3://crabby-images/db679/db6795b85d84039216f4d0d12597ecb30cea030f" alt=""
小结:
一对多、多对多应该有更mybatis的方法,不过现在还没学到。还有QuestionMapper文件中的ResultType都写成类的名字而不需要因为查询多个对象去写成list之类的东西。
网友评论