国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL實現(xiàn)數(shù)據(jù)更新的示例詳解

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

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

1.所有字段全部更新;

2.根據(jù)條件更新字段中的某部分內(nèi)容;

3.根據(jù)不同的條件更新不同的值

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

一、方法分類

二、具體用法

(1)根據(jù)條件更新值

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

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

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

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

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

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

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

使用 if

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

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

使用 case when

把表中 [符合條件的行的] 列名1字段中符合條件1的內(nèi)容修改為值1 [,符合條件2的修改為值2,...] [,列名2字段中符合條件21的內(nèi)容修改為值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)根據(jù)條件更新值

把 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字段中的名字改為優(yōu)秀;score大于等于60小于90的score字段全部改為1,name字段中的名字改為良好。

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

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

idnamescore1優(yōu)秀22良好13不及格0

到此這篇關(guān)于MySQL實現(xiàn)數(shù)據(jù)更新的示例詳解的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù)更新內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
主站蜘蛛池模板: 理论片黄色 | 欧美巨大video粗暴 | 精品综合久久久久久88小说 | 精品亚洲成a人片在线观看 精品亚洲成a人在线播放 | 国产精品久久久久久免费播放 | 成人在线免费 | 免费在线国产视频 | 一级毛毛片毛片毛片毛片在线看 | 久久精品免费播放 | 青青视频国产依人在线 | 久久亚洲网 | 欧美色xxxx | 成年网站免费视频黄 | 韩国毛片免费 | 韩国欧美一级毛片 | 手机看片日韩国产一区二区 | 欧美成人午夜片一一在线观看 | 高清一级片 | 一区二区三区国产 | 国产午夜精品一区二区三区不卡 | 亚洲美女视频一区二区三区 | 亚洲一区二区三区四区 | 亚洲欧美日韩中文字幕在线 | 亚洲性网 | 三级网站视频在线观看 | 日韩欧美二区 | 亚洲国产一区二区三区四区五区 | 久久精品国产91久久综合麻豆自制 | 拍拍拍又黄又爽无挡视频免费 | 国产精品国产国产aⅴ | 欧美成人免费全部色播 | 久久久久久综合对白国产 | 一级黑人 | 夜夜躁狠狠躁日日躁2021 | 精品国产一二三区在线影院 | 一区二区三区高清在线 | 精品国产中文一级毛片在线看 | 亚洲第一区视频在线观看 | 国产美女视频黄a视频全免费网站 | 99久久综合精品免费 | 亚州一级片 |