面试题:连接查询和子查询

今天碰到个有意思的面试题,主要是被第2小题难住了(和同事灵感碰撞才把问题解决),所以做个demo记录一下。

1、首先我们分别创建 tab_user_info 和 tab_dict_sex 数据表:

CREATE TABLE `tab_user_info` (
  `fld_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增id',
  `fld_name` varchar(30) DEFAULT NULL COMMENT '姓名',
  `fld_sexid` varchar(10) DEFAULT NULL COMMENT '性别id',
  `fld_age` int(11) DEFAULT '0' COMMENT '年龄',
  PRIMARY KEY (`fld_id`)
) ENGINE=MyISAM AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4;
CREATE TABLE `tab_dict_sex` (
  `fld_sexid` varchar(10) NOT NULL COMMENT '性别id',
  `fld_sexinfo` varchar(255) DEFAULT NULL COMMENT '性别描述',
  PRIMARY KEY (`fld_sexid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4;

2、我们来初始化一些数据

 

3、连接查询

(这个是使用的内连接,a表和b表的相等条件都存在数据才会显示出来)

select a.fld_id,a.fld_name,b.fld_sexinfo from tab_user_info as a,tab_dict_sex as b where a.fld_sexid=b.fld_sexid;

 

4、子查询

(和左连接查询效果一样,利用主表 tab_user_info 的 fld_sexid 去 tab_dict_sex 表中获取性别描述 )

SELECT g.fld_id,g.fld_name, (SELECT u.fld_sexinfo FROM tab_dict_sex u WHERE u.fld_sexid=g.fld_sexid) as sexinfo FROM tab_user_info g;

 

学无止境,努力学习提高自己!

thanks~

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值