java - MYBATIS外键对应表的字段查询本表

 黄自安_725 发布于 2022-10-26 14:59

有两张表,一张为GUEST代表旅客,一张为PREORDER代表订单,现在我想要用户输入GUEST旅客的名字GNAME就能查询到PREORDER订单,如何做到?
PREORDER中有一个字段GID作为外键关联到GUEST中的主键GID,但是旅客的名字GNAME却什么都不是,只是GUEST中的普通字段而已

我觉得我已经描述的很清楚了吧,代码还需要贴嘛? 求大神解惑呀..


PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

  
  


    
    
    
    
    
    
    
    
      


    
    
    
        
    
        
    
    
    
    
    



    
    


    
    
    
    
    
    
    






    
        
        
            and poCreateTime between #{beginDate} and #{endDate}
        
                
    



    
        order by
        
            
                po_id
            
            
                poCreateTime
            
        
        
            ASC
        
        
            DESC
        
    




    select * from
    (select row_number() over(



= #{pageno} and rn <= #{pagesize} ]]>






3 个回答
  • dao接口:public List<map> queryInfo();

    <select id="queryInfo" resultType="hashmap">
    select a.??,b.?? from guest a left join preorder b on a.gid = b.gid
    </select>

    得到的结果,看你想转成什么格式了。如果想自定义key,直接a.xx as "你要的key键"

    2022-11-12 01:39 回答
  • 求大神解惑呀

    2022-11-12 01:39 回答
  • SELECT * FROM PREORDER GID=(SELECT GID FROM GUEST WHERE GNAME='旅客名称')


    SELECT * FROM PREORDER t1 LEFT JOIN GUEST t2 ON t1.GID=t2.GID WHERE t2.GNAME='旅客名称'

    试试这个看看吧。

    2022-11-12 01:39 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有