开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 782|回复: 11
收起左侧

[已解决] 问一个mysql语句相关问题

 关闭 [复制链接]
结帖率:67% (40/60)
发表于 2021-12-28 15:55:05 | 显示全部楼层 |阅读模式   江苏省扬州市
30精币
cha询表名为 "成绩表" 中,身高为170,175,180所对应的字段 成绩 分别为 10,20,30的结果

即:
身高     成绩
170  ---  10
175  ---   20
180  ---   30

即:170且成绩为10,175且成绩为20,180且成绩为30的语句,只是一个示例,不要单纯的and语句,实际可能是这50个记录一一对应另外50个记录

最佳答案

查看完整内容

也许这样吧。

求助知识:请将问题描述清楚,最好把你有问题的源码打包上传上来,这样更方便大家帮助你。
友情提醒:本版被采纳的主题可在 申请荣誉值 帖子申请荣誉值,获得 3点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。

结帖率:100% (2/2)
发表于 2021-12-28 15:55:06 | 显示全部楼层   内蒙古自治区通辽市
[SQL] 纯文本查看 复制代码
SELECT * FROM tab WHERE sg=170 AND cj=10
UNION
SELECT * FROM tab WHERE sg=180 AND cj=20
UNION
SELECT * FROM tab WHERE sg=190 AND cj=30



也许这样吧。

点评

找到一个更方便一点的,但这个还不是最好的 SELECT * FROM table WHERE (sg, cj) IN ((170, 10),(180, 20),(190, 30))   江苏省扬州市  发表于 2021-12-28 22:24

评分

参与人数 1荣誉 +3 收起 理由
笨潴 + 3 热心帮助他人,荣誉+3,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (35/35)

签到天数: 11 天

发表于 2021-12-28 15:58:00 | 显示全部楼层   上海市上海市
select score from t_score where height in (170,175,180)
回复

使用道具 举报

结帖率:100% (2/2)
发表于 2021-12-28 16:00:33 | 显示全部楼层   内蒙古自治区通辽市
多条件,不是AND就是OR。
其实我没理解,还是请楼主详细说说。
回复

使用道具 举报

结帖率:67% (40/60)

签到天数: 11 天

 楼主| 发表于 2021-12-28 16:00:46 | 显示全部楼层   江苏省扬州市
半晚安睡 发表于 2021-12-28 15:58
select score from t_score where height in (170,175,180)

这个只是cha询了包含 170.175.180 的记录啊,我想要的是170且成绩为10,175且成绩为20,180且成绩为30的语句
回复

使用道具 举报

结帖率:67% (40/60)

签到天数: 11 天

 楼主| 发表于 2021-12-28 16:03:12 | 显示全部楼层   江苏省扬州市
寒潮 发表于 2021-12-28 16:00
多条件,不是AND就是OR。
其实我没理解,还是请楼主详细说说。

身高 (170,175,180)   成绩(10,20,30) 我想让这两个字段值分别同时对应满足的结果
回复

使用道具 举报

结帖率:86% (19/22)
发表于 2021-12-28 16:05:04 | 显示全部楼层   四川省成都市
louxu163 发表于 2021-12-28 16:00
这个只是cha询了包含 170.175.180 的记录啊,我想要的是170且成绩为10,175且成绩为20,180且成绩为30的 ...

数据表的完整性你都不给出来,人家怎么帮你呢?这个是我很好奇的一个事
回复

使用道具 举报

结帖率:100% (5/5)
发表于 2021-12-28 16:09:41 | 显示全部楼层   广西壮族自治区南宁市
楼上的union ,或者创建一个临时表,存放身高和成绩,然后再inner join关联也可以。数量大的时候可以考虑用这个方式
回复

使用道具 举报

结帖率:67% (40/60)

签到天数: 11 天

 楼主| 发表于 2021-12-28 16:14:09 | 显示全部楼层   江苏省扬州市
寒潮 发表于 2021-12-28 16:07
[mw_shl_code=sql,true]SELECT * FROM tab WHERE sg=170 AND cj=10
UNION
SELECT * FROM tab WHERE sg=180  ...

这个办法能实现效果,数量大的情况下,有更高级的语法吗,比方将值括号起来作为集合,按顺序对应另一个集合的
回复

使用道具 举报

结帖率:100% (2/2)
发表于 2021-12-28 16:24:07 | 显示全部楼层   内蒙古自治区通辽市
louxu163 发表于 2021-12-28 16:14
这个办法能实现效果,数量大的情况下,有更高级的语法吗,比方将值括号起来作为集合,按顺序对应另一个集 ...

cha询语句根据你的需要来弄就可以,保持各个cha询语句的cha询列一致就行。
结果用UNION来进行连接
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表