电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL實現數據更新的示例詳解

瀏覽:143日期:2023-02-18 16:43:38
目錄
  • 一、方法分類
  • 二、具體用法
    • (1)根據條件更新值
    • (2)按照不同條件(批量)更新不同值
  • 三、實例
    • (1)根據條件更新值
    • (2)按照不同條件更新不同值

一般在更新時會遇到以下場景:

1.所有字段全部更新;

2.根據條件更新字段中的某部分內容;

3.根據不同的條件更新不同的值

以下是幾種場景中常用的update方法。

一、方法分類

二、具體用法

(1)根據條件更新值

根據指定條件更新(多列)(全部更新)

把表中 [符合條件的行的] 列名1字段中的值全部修改為值1 [,列名2字段中的值修改為值2]。

update 表名 set 列名1 = 值1 [,列名2=值2][where 條件];

替換指定值(多列)(部分更新)

把表中 [符合條件的行的] 列名1字段中的查找內容全部修改為替換內容 [,列名2字段中的查找內容全部修改為替換內容]。

update 表名 set 列名1 = replace(列名1, "查找內容", "替換內容") [,列名2 = replace(列名2, "查找內容", "替換內容")] [where 條件];

(2)按照不同條件(批量)更新不同值

使用 if

把表中 [符合條件的行的] 列名1字段中符合條件1的內容修改為值1,否則修改為值2 [,列名2字段中符合條件2的內容修改為值3,否則修改為值4]。

update table set 	列名1 = if(條件1,值1,值2),    列名2 = if(條件2,值3,值4)[where 條件];

使用 case when

把表中 [符合條件的行的] 列名1字段中符合條件1的內容修改為值1 [,符合條件2的修改為值2,...] [,列名2字段中符合條件21的內容修改為值21,符合條件22的修改為值22,...] 。

update table set 列名1 =    casewhen 條件1 then 值1when 條件2 then 值2when 條件3 then 值3...    end,    列名2 =    casewhen 條件21 then 值21when 條件22 then 值22when 條件23 then 值23...    end[where 條件];

三、實例

students 表 (id表示主鍵,name是姓名,score是平均成績)

idnamescore1李明992張三743孫華59

(1)根據條件更新值

把 students 表中 name 為張三的 score 字段的值全部修改為100。

#使用whereupdate students set score = 100where name = "張三";
idnamescore1李明992張三1003孫華59

把 students 表中 id 大于等于2的所有行中 score 中59的部分全部修改為0,name 中三的部分全部修改為四。

#使用replaceupdate students set score = replace(score,59,0),	name = replace(name,"三","四")where id >= 2;

注意:張三替換之后是張四,并不是只有字段等于三時才能替換。

idnamescore1李明992張四743孫華0

(2)按照不同條件更新不同值

請把students表中score小于60的score字段全部改為0,否則改為100,name字段中的名字改為不及格,否則改為及格。

#批量更新多值 + ifupdate students set     score = if(score < 60,0,100),    name = if(score < 60,"不及格","及格");
idnamescore1及格1002及格1003不及格0

注意:更新的值要滿足建表時的字段類型。比如score是int類型就不能更新為char類型。

請把students表中score小于60的score字段全部改為0,name字段中的名字改為不及格;score大于等于90的score字段全部改為2,name字段中的名字改為優秀;score大于等于60小于90的score字段全部改為1,name字段中的名字改為良好。

#批量更新多值 + case whenupdate students set     name = casewhen score < 60 then "不及格"		when score >= 90 then "優秀"else "良好"    end,		score = casewhen score < 60 then 0		when score >= 90 then 2else 1    end;

注意:更新的時候是按照代碼語句的先后順序更新的。可以嘗試先更新score后更新name,結果是不一樣的。

idnamescore1優秀22良好13不及格0

到此這篇關于MySQL實現數據更新的示例詳解的文章就介紹到這了,更多相關MySQL數據更新內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MySQL
主站蜘蛛池模板: ISO9001认证咨询_iso9001企业认证代理机构_14001|18001|16949|50430认证-艾世欧认证网 | 沧州友城管业有限公司-内外涂塑钢管-大口径螺旋钢管-涂塑螺旋管-保温钢管生产厂家 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 技德应用| 海尔生物医疗四川代理商,海尔低温冰箱四川销售-成都壹科医疗器械有限公司 | 事迹材料_个人事迹名人励志故事| 同学聚会纪念册制作_毕业相册制作-成都顺时针宣传画册设计公司 | 叉车电池-叉车电瓶-叉车蓄电池-铅酸蓄电池-电动叉车蓄电池生产厂家 | 亳州网络公司 - 亳州网站制作 - 亳州网站建设 - 亳州易天科技 | 等离子表面处理机-等离子表面活化机-真空等离子清洗机-深圳市东信高科自动化设备有限公司 | 游泳池设备安装工程_恒温泳池设备_儿童游泳池设备厂家_游泳池水处理设备-东莞市君达泳池设备有限公司 | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 河南空气能热水器-洛阳空气能采暖-洛阳太阳能热水工程-洛阳润达高科空气能商行 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 广东恩亿梯电源有限公司【官网】_UPS不间断电源|EPS应急电源|模块化机房|电动汽车充电桩_UPS电源厂家(恩亿梯UPS电源,UPS不间断电源,不间断电源UPS) | 企业彩铃制作_移动、联通、电信集团彩铃上传开通_彩铃定制_商务彩铃管理平台-集团彩铃网 | 挤塑板-XPS挤塑板-挤塑板设备厂家[襄阳欧格] | 建筑工程资质合作-工程资质加盟分公司-建筑资质加盟 | 进口试验机价格-进口生物材料试验机-西安卡夫曼测控技术有限公司 | 下水道疏通_管道疏通_马桶疏通_附近疏通电话- 立刻通 | 蓝鹏测控平台 - 智慧车间系统 - 车间生产数据采集与分析系统 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 苏州柯瑞德货架-仓库自动化改造解决方案 | 塑胶地板-商用PVC地板-pvc地板革-安耐宝pvc塑胶地板厂家 | 北京京云律师事务所| 滚筒烘干机_转筒烘干机_滚筒干燥机_转筒干燥机_回转烘干机_回转干燥机-设备生产厂家 | 赛尔特智能移动阳光房-阳光房厂家-赛尔特建筑科技(广东)有限公司 | 大立教育官网-一级建造师培训-二级建造师培训-造价工程师-安全工程师-监理工程师考试培训 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 东莞精密模具加工,精密连接器模具零件,自動機零件,冶工具加工-益久精密 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 杭州翻译公司_驾照翻译_专业人工翻译-杭州以琳翻译有限公司官网 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 广东风淋室_广东风淋室厂家_广东风淋室价格_广州开源_传递窗_FFU-广州开源净化科技有限公司 | 赛尔特智能移动阳光房-阳光房厂家-赛尔特建筑科技(广东)有限公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 制氮设备_PSA制氮机_激光切割制氮机_氮气机生产厂家-苏州西斯气体设备有限公司 | 14米地磅厂家价价格,150吨地磅厂家价格-百科 | 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | 税筹星_灵活用工平台_企业财务顾问_财税法薪综合服务平台 |