php+mysql,用户A在数据库有N条记录。当一条记录的first字段值变为1,则该用户其他的记录的first都为0?

如题,我的本办法是操作2次数据库,这个肯定不是好办法$db->query("UPDATE".table('user')."SETfirst='0'WHEREuserid=... 如题,我的本办法是操作2次数据库,这个肯定不是好办法
$db->query("UPDATE ".table('user')." SET first='0' WHERE userid=".$suser);
$db->query("UPDATE ".table('user')." SET first='1' WHERE id='$id' AND userid=".$suser);

高手指点下
也就是说一个用户只能有一个first为1的记录,其他的都为0
展开
 我来答
songyipangbuo
2014-12-18 · TA获得超过744个赞
知道小有建树答主
回答量:190
采纳率:100%
帮助的人:252万
展开全部
执行一条就可以实现
$db->query("UPDATE ".table('user')." SET first=case id when {$id} then 1 else 0 end WHERE userid=".$suser);
更多追问追答
追问
真的能一条语句实现吗?我去试试看,谢谢了。我也觉得应该有更简便的方法的。

能给我解释下这个语句的意思吗?他是要遍历userid=".$suser的记录,看是不是id=$id,是就设置first为1,不是就设置first为0?
追答
恩恩,理解的很正确。。
名字想一万年
2014-12-18 · 超过12用户采纳过TA的回答
知道答主
回答量:22
采纳率:0%
帮助的人:10.4万
展开全部
你的意思是已经知道这个用户的一条记录的first的值变成1了吧!那么这个
$id为first字段为1的那个字段的id!
$db->query("UPDATE ".table('user')." SET first='0' WHERE id!={$id} and userid={$suser}");
更多追问追答
追问
你误解了。我的意思是
打个比方:用户A在数据库里有3条记录。分别id=1,2,3
id=1的记录first是1,其他都是0

现在要把id=3的那条记录设为first=1了。同时其他的1、2的first都要变为0.
追答
只能通过两条sql语句了!不能在一个语句中对一个一段设置2种值!
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式