如何更新表中id值最大的一条记录,下面语句哪里出错了?

我的id值是自增的。使用如下语句:update表名set字段名=‘11’whereidin(selectmax(id));在mysql中使用,出现的结果是更新了所有的记录... 我的id值是自增的。使用如下语句:
update 表名 set 字段名=‘11’ where id in (select max(id));在mysql中使用,出现的结果是更新了所有的记录。我只想更新最后一条记录(就是id值最大的那条记录)
展开
 我来答
coder_tmp
2012-07-11 · TA获得超过443个赞
知道小有建树答主
回答量:547
采纳率:100%
帮助的人:347万
展开全部
你可以试试
select * from 表名 where id in (select max(id))
看看得到多少条记录,如果得到一条,那么更新的就是一条,如果得到所有记录,那么自然更新的是所有。
所以 应该用楼上的方法更新才对,即:
--------------------------------------------------
mikejodden | 三级
update 表名 set 字段名=‘11’ where id = (select max(id)FROM 表名)
mikejodden
2012-07-11 · TA获得超过383个赞
知道小有建树答主
回答量:303
采纳率:0%
帮助的人:274万
展开全部
update 表名 set 字段名=‘11’ where id = (select max(id)FROM 表)
追问
后面接from 表名将出错。后来我用如下语句:
update 表名 set 字段名=‘11’ order by id desc limit 1
可以实现更新最后一条
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式