重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
thinkphp里面其实跟原生语句没有什么区别,你可以用where限定更新条件,再save($data)中将你要更新的数据存在data里面。这样是你要把数据更新成一样的时候。如果更新的字段及值不一样的话,据我所知就只能一条条的循环更新了。
创新互联从2013年开始,先为向阳等服务建站,向阳等地企业,进行企业商务咨询服务。为向阳企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
MySQL
Update
Set
更新数据
UPDATE
更新
UPDATE
SET
语法用于修改更新数据表中的数据。
语法:
UPDATE
tb_name
SET
column1
=
new_value1,column2
=
new_value2,…
WHERE
definition
该语法将数据表中符合
WHERE
条件的记录中的
column1
的值更新为
new_value1,column2
的值更新为
new_value2
,以此类推。如果省略
WHERE
条件,则会将表中所有记录的
column
值进行更新。
例子:
?php
$conn
=
@mysql_connect("localhost","root","root123");
if
(!$conn){
die("连接数据库失败:"
.
mysql_error());
}
mysql_select_db("test",
$conn);
mysql_query("set
names
'gbk'");
$sql
=
"UPDATE
user
SET
=
'xiaoming@163点抗 '
WHERE
username
=
'小明'";
if(mysql_query($sql,$conn)){
echo
"更新数据成功!";
}
else
{
echo
"更新数据失败:".mysql_error();
}
?
更新前数据:
uid
username
password
regdate
1
admin
b7e591c246d010bb2ccd77d52490c85e
admin@5idev点抗
1277992339
2
小明
a193686a53e4de85ee3f2ff0576adf01
xiao@163点抗
1278063917
3
Jack
0193686a35e4de85ee3f2ff0567adf49
jack@gmail点抗
1278061380
4
小王
e10adc3949ba59abbe56e057f20f883e
12345@163点抗
1289632955
例子将
user
表中
username
为
小明
的
修改为
xiaoming@163点抗
。
更新后数据:
uid
username
password
regdate
1
admin
b7e591c246d010bb2ccd77d52490c85e
admin@5idev点抗
1277992339
2
小明
a193686a53e4de85ee3f2ff0576adf01
xiaoming@163点抗
1278063917
3
Jack
0193686a35e4de85ee3f2ff0567adf49
jack@gmail点抗
1278061380
4
小王
e10adc3949ba59abbe56e057f20f883e
12345@163点抗
1289632955
UPDATE
表达式
UPDATE
语法允许
SET
后面跟表达式。
例子
1
:
UPDATE
article
SET
pv
=
pv+1
WHERE
id
=
123
该例子让
id
为
123
的文章在被点击阅读的时候点击量加
1
。
例子
2
:
UPDATE
persondata
SET
age
=
age*2,
age
=
age+1
该例子
SET
后面跟了两个表达式:age
=
age*2(年龄加倍),age
=
age+1(再加
1
)。这种多个表达式的情况,是按照从左往右顺序执行的。
update用mysql_query执行的时候能得到返回值,这个返回值说明了执行是否成功。
然后用mysql_affected_rows判断是否修改了数据
两个判断组合起来用就能满足你的需求了