MySQL實現(xiàn)數(shù)據(jù)更新的示例詳解
一般在更新時會遇到以下場景:
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 =
case
when 條件1 then 值1
when 條件2 then 值2
when 條件3 then 值3
...
end,
列名2 =
case
when 條件21 then 值21
when 條件22 then 值22
when 條件23 then 值23
...
end
[where 條件];
三、實例
students 表 (id表示主鍵,name是姓名,score是平均成績)
| id | name | score |
|---|---|---|
| 1 | 李明 | 99 |
| 2 | 張三 | 74 |
| 3 | 孫華 | 59 |
(1)根據(jù)條件更新值
把 students 表中 name 為張三的 score 字段的值全部修改為100。
#使用where update students set score = 100 where name = '張三';
| id | name | score |
|---|---|---|
| 1 | 李明 | 99 |
| 2 | 張三 | 100 |
| 3 | 孫華 | 59 |
把 students 表中 id 大于等于2的所有行中 score 中59的部分全部修改為0,name 中三的部分全部修改為四。
#使用replace update students set score = replace(score,59,0), name = replace(name,'三','四') where id >= 2;
注意:張三替換之后是張四,并不是只有字段等于三時才能替換。
| id | name | score |
|---|---|---|
| 1 | 李明 | 99 |
| 2 | 張四 | 74 |
| 3 | 孫華 | 0 |
(2)按照不同條件更新不同值
請把students表中score小于60的score字段全部改為0,否則改為100,name字段中的名字改為不及格,否則改為及格。
#批量更新多值 + if
update students
set
score = if(score < 60,0,100),
name = if(score < 60,'不及格','及格');
| id | name | score |
|---|---|---|
| 1 | 及格 | 100 |
| 2 | 及格 | 100 |
| 3 | 不及格 | 0 |
注意:更新的值要滿足建表時的字段類型。比如score是int類型就不能更新為char類型。
請把students表中score小于60的score字段全部改為0,name字段中的名字改為不及格;score大于等于90的score字段全部改為2,name字段中的名字改為優(yōu)秀;score大于等于60小于90的score字段全部改為1,name字段中的名字改為良好。
#批量更新多值 + case when
update students
set
name = case
when score < 60 then '不及格'
when score >= 90 then '優(yōu)秀'
else '良好'
end,
score = case
when score < 60 then 0
when score >= 90 then 2
else 1
end;
注意:更新的時候是按照代碼語句的先后順序更新的??梢試L試先更新score后更新name,結(jié)果是不一樣的。
| id | name | score |
|---|---|---|
| 1 | 優(yōu)秀 | 2 |
| 2 | 良好 | 1 |
| 3 | 不及格 | 0 |
到此這篇關于MySQL實現(xiàn)數(shù)據(jù)更新的示例詳解的文章就介紹到這了,更多相關MySQL數(shù)據(jù)更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢
這篇文章主要介紹了Mysql數(shù)據(jù)庫使用concat函數(shù)執(zhí)行SQL注入查詢,concat函數(shù)在SQL注入查詢中會有意想不到的作用,本文就起講解它的使用,需要的朋友可以參考下2015-04-04
MySQL自動填充create_time和update_time的兩種方式
當我們創(chuàng)建業(yè)務表的時候 通常都需要設置create_time 和 update_time,下面這篇文章主要給大家介紹了關于MySQL自動填充createTime和updateTime的兩種方式,需要的朋友可以參考下2022-05-05
通過sql語句將blob里的char取出來轉(zhuǎn)成數(shù)字保存在其它字段
現(xiàn)在需要將blob里地17、18、19三個字段里的數(shù)據(jù)作為數(shù)字保存在blob外新增的三個字段Gem1 Gem2 Gem3上。2011-09-09

