mysql两表查询的问题。
迷茫
迷茫 2017-04-17 13:07:50
[MySQL讨论组]



那么问题来了,工资是属于敏感和金钱组的,为啥这样不出来呢,语句如下。和上图一样~

select f.field_name,g.group_name from dmp_field as f,dmp_field_group
 as g where f.group_id=g.id;

如果各位大神觉得我描述不清楚,我想要的结果

已经解决
ps:最后还是加个关联表吧,多对多。。
感谢各位~

select f.field_name,f.id,f.is_system,(select group_concat(g.group_name) from dmp_field_group as g where find_in_set (g.id,f.group_id)) as group_name from dmp_field as f 【where true】

再加两张图片:FIND_IN_SETGROUP_CONCAT

足够多表关联了~还有,一定要大写啊。刚刚被老大骂了~

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(3)
黄舟
SELECT f.field_name,(SELECT GROUP_CONCAT(g.group_name)  FROM dmp_field_group as g WHERE find_in_set(g.id,f.group_id)) AS group_name FROM dmp_field AS f

一定要写可以类似与这样子写,不过一般确实会有个中间表记录对应关系!

怪我咯

group 中的 id 并没有为 ”53,54“ 的值

PHP中文网

f.group_id=g.id 是不是应该用in 看到有逗号分隔两个id 我只是猜的!!

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号