MYSQL 高级查询 一个字段根据多条件 执行排序..
SELECTecm_goods_attr.goods_id,CONCAT(',',GROUP_CONCAT(DISTINCT(CASEWHEN(ecm_goods_att...
SELECT ecm_goods_attr.goods_id, CONCAT( ',', GROUP_CONCAT( DISTINCT (
CASE WHEN (
ecm_goods_attr.attr_name != '估值'
)
THEN (
ecm_goods_attr.attr_value
)
END )
ORDER BY ecm_goods_attr.attr_id ASC
SEPARATOR ',' ) , ','
) AS ops, ecm_goods_ext.guarantee_type_id AS guarantee_type_id
FROM ecm_goods_attr, ecm_goods_ext
WHERE ecm_goods_attr.goods_id = ecm_goods_ext.goods_id
GROUP BY ecm_goods_attr.goods_id
ORDER BY ecm_goods_ext.goods_id
这里查询的结果是,一个表里的两个字段,加上另外一个表的字段..另外,我还要加一个字段,是来自表一的字段,等于'估值'的字段..如何写代码添加这个查询字段. 展开
CASE WHEN (
ecm_goods_attr.attr_name != '估值'
)
THEN (
ecm_goods_attr.attr_value
)
END )
ORDER BY ecm_goods_attr.attr_id ASC
SEPARATOR ',' ) , ','
) AS ops, ecm_goods_ext.guarantee_type_id AS guarantee_type_id
FROM ecm_goods_attr, ecm_goods_ext
WHERE ecm_goods_attr.goods_id = ecm_goods_ext.goods_id
GROUP BY ecm_goods_attr.goods_id
ORDER BY ecm_goods_ext.goods_id
这里查询的结果是,一个表里的两个字段,加上另外一个表的字段..另外,我还要加一个字段,是来自表一的字段,等于'估值'的字段..如何写代码添加这个查询字段. 展开
若以下回答无法解决问题,邀请你更新回答
3个回答
展开全部
把查询结果做为虚拟表 比如 AS aa,然后在去关联.
更多追问追答
追问
直接这样的话如何添加? 我这是要做成视图的.
追答
其实就是查2次
SELECT aa.goods_id,aa.ops,aa.guarantee_type_id,bb.ops2 FROM
(你写的语句) as aa
join
(语句里的条件变为='估值' as ops2) as bb
on aa.goods_id=bb.goods_id
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我觉得你应该在数据结构做一些功夫, 做一些提高效率的冗余
你这样写SQL效率太低了, 并发稍高一点点, 就抗不住 了
你这样写SQL效率太低了, 并发稍高一点点, 就抗不住 了
追问
现在的问题是不能和不好修改表结构...只能用代码实现.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
飘过. 等回答学习一下.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询