最近遇到一個需求:mysql中A表和B表都有(id, age)欄位,現在想讀取B表的age欄位,將其update到A表對應ID的age欄位中去,我直接想到了一種方案:用Python讀取B表,獲得{id:age}形式的資料,然後根據每個ID和age的值依次update A表。
兩個表分別定義和資料如下:
A表定義:
| Field |
Type |
Comment |
| id |
int(11) |
|
| name |
varchar(20) |
|
| age |
int(11) |
|
資料:
1,name1,0
2,name2,0
3,name3,0
4,name4,0
5,name5,0
B表定義
| Field |
Type |
Comment |
| id |
int(11) |
|
| age |
int(11) |
|
資料:
1,11
2,21
3,31
4,41
5,51
python代碼來實現
| 代碼如下 |
複製代碼 |
# -*- encoding:utf8 -*- ''' @author: crazyant.net 讀取B表的(id, age)資料,然後依次更新A表; ''' from common.DBUtil import DB dbUtil = DB('127.0.0.1',3306,'root','','test') rs = dbUtil.query("SELECT id,age FROM table_b") for row in rs: (idv,age)=row print (idv,age) update_sql="update table_a set age='%s' where id='%s';"%(age,idv) print update_sql dbUtil.update(update_sql) print 'over' |
其實一條SQL語句就可以搞定
看了看代碼,實在是簡單,於是網上搜了一下mysql能不能根據一個表更新另一個表,結果發現update本身就支援多個表更新的功能。
| 代碼如下 |
複製代碼 |
UPDATE table_a,table_b SET table_a.age=table_b.age WHERE table_a.id=table_b.id; |
用python代碼就顯得是大炮打蚊子多次一舉了。