mysql中sql块如何使用
这篇文章主要介绍了mysql中sql块如何使用,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。
mysql中sql块的用法:1、进行非默认的排序;2、更新替换某一个字段中的特定字符串【SELECT a.id FROM(..)】;3、求比例的sql【b.num / a.sum * 100】。
mysql中sql块的用法:
1、使用非默认的排序,例如使用213之类的排序
可以使用如下方法
SELECT DISTINCTpg.part_grp_id,pg.part_grp_name,pg.equip_category_idFROMcost_part_grp pg,cost_part_kit pk,cost_part_event peWHEREpe.mdl_ver_id IN (SELECTs.mdl_ver_idFROMcost_fleet_model sWHEREs.fleet_id = 1002)AND pe.part_kit_id = pk.part_kit_idAND pk.part_grp_id = pg.part_grp_idORDER BYCASE pg.equip_category_idWHEN 2 THEN1WHEN 1 THEN2WHEN 4 THEN3ELSE4END
2、mysql更新替换某一个字段中的特定字符串
UPDATE t_bss_employeesSET mobilephone = REPLACE (mobilephone, "2129", "0000")WHEREid IN (SELECTa.idFROM(SELECTidFROMt_bss_employeesWHEREmobilephone IN ('18121299262','18121299247','18121299206','18121299209')) AS a)
将mobilephone字段中的2129字符串替换为0000
使用当前表为条件更新当前表。需要在条件处再添加一个()构建一个虚拟表
3、求比例的sql
select a.style, ROUND( b.num / a.sum * 100, 2 ) as styleRate from (SELECT count(qspc.id) sum ,qq.style stylefrom t_qc_security_plan_comment qspc inner join t_qc_question qqon qq.id = qspc.question_idLEFT JOIN t_qc_address qa ON qa.id = qspc.address_idLEFT JOIN t_system_organ so on qa.hospital = so.idWHERE qq.scr_level is not NULLand qq.type = 3 and so.tenant_code = 'zzyy'GROUP BY style) a left join (SELECT count(qspc.id) num ,qq.style stylefrom t_qc_security_plan_comment qspc inner join t_qc_question qqon qq.id = qspc.question_idLEFT JOIN t_qc_address qa ON qa.id = qspc.address_idLEFT JOIN t_system_organ so on qa.hospital = so.idWHERE qq.scr_level is not NULLand qq.type = 3 and so.tenant_code = 'zzyy'and qspc.is_bad =0GROUP BY style) b on a.style = b.style
计算逻辑是分别求总数和平均数。然后两数相除再用round求精度
感谢你能够认真阅读完这篇文章,希望小编分享mysql中sql块如何使用内容对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,遇到问题就找亿速云,详细的解决方法等着你来学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。