mysql数据库条件批量更新?该如何处理
Jun 13, 2016 pm 12:55 PM
mysql数据库条件批量更新?
有表格:
id datetime youliang_procd
51555 2013-1-18 7:40 173
51556 2013-1-18 7:43 173
51557 2013-1-18 7:50 0
51558 2013-1-18 7:50 0
51572 2013-1-18 8:03 0
51573 2013-1-18 8:04 0
51574 2013-1-18 8:04 0
51575 2013-1-18 8:05 0
51576 2013-1-18 8:11 170
51577 2013-1-18 8:14 170
51578 2013-1-18 8:14 0
51579 2013-1-18 8:15 0
51580 2013-1-18 8:21 167
51581 2013-1-18 8:24 167
51582 2013-1-18 8:30 0
51583 2013-1-18 8:30 0
51584 2013-1-18 8:30 0
问题:若字段youliang_procd=0,将youliang_procd的值更新为上一条记录该字段的值,更新后结果为:
id datetime youliang_procd
51555 2013-1-18 7:40 173
51556 2013-1-18 7:43 173
51557 2013-1-18 7:50 173
51558 2013-1-18 7:50 173
51572 2013-1-18 8:03 173
51573 2013-1-18 8:04 173
51574 2013-1-18 8:04 173
51575 2013-1-18 8:05 173
51576 2013-1-18 8:11 170
51577 2013-1-18 8:14 170
51578 2013-1-18 8:14 170
51579 2013-1-18 8:15 170
51580 2013-1-18 8:21 167
51581 2013-1-18 8:24 167
51582 2013-1-18 8:30 167
51583 2013-1-18 8:30 167
51584 2013-1-18 8:30 167
请问大侠,这条sql语句怎么写(在MySql数据库中),谢谢,在线等!
------解决方案--------------------
这个一定要用SQL完成,如果用代码,更方便吧
------解决方案--------------------
可以用 SQL 直接完成
set @v:=0;<br /> <br /> update tbl_name, (select id, @v:=if(youliang_procd,youliang_procd,@v) as u from tbl_name) t<br /> set tbl_name.youliang_procd=t.u where tbl_name.id=t.id;
共两条指令,在 php 中要分别执行
其中
set @v:=0 用于声明一个用户变量
select id, @v:=if(youliang_procd,youliang_procd,@v) as u from tbl_name 用于将非空的 youliang_procd 字段值带入下一条
tbl_name 你待操作的表名
------解决方案--------------------
SQL 直接完成了??
------解决方案--------------------
是的!
如果结合 php 来完成,就需要逐条读取、判断、修改
这将是一件十分痛苦的过程

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Penyelesaian: Organisasi anda memerlukan anda menukar PIN anda

Cara melaraskan tetapan sempadan tetingkap pada Windows 11: Tukar warna dan saiz

Bagaimana untuk menukar warna bar tajuk pada Windows 11?

Bagaimana untuk mendayakan atau melumpuhkan pratonton lakaran kecil bar tugas pada Windows 11

Masalah Ralat OOBELANGUAGE dalam Pembaikan Windows 11/10

Paparkan panduan penskalaan pada Windows 11

10 Cara untuk Melaraskan Kecerahan pada Windows 11

Bagaimana untuk mematikan pengesahan penyemakan imbas peribadi pada iPhone dalam Safari?
