mysql中能不能这么写sql语句 如果不能的话怎么能实现在数据库中计算时间差

mysql>updatetimetestsettime=((selecttime1fromtimetestwhereid='1')-(selecttime2fromtim... mysql> update timetest set time = ((select time1 from timetest where id = '1')-(select time2 from timetest where id = '1')) where id = '1';
1093 - You can't specify target table 'timetest' for update in FROM clause
展开
 我来答
zxd9915
2013-11-25 · TA获得超过299个赞
知道小有建树答主
回答量:461
采纳率:50%
帮助的人:211万
展开全部
根据你的语句,直接执行:
update timetest set time=(time1-time2) where id='1';
应该就可以了。
追问
mysql> update timetest set time=(time2-time1
) where id='1';
1292 - Incorrect datetime value: '21836.000000' for column 'time' at row 1

是不是我表的类型设置的不对的呢 时间要算差的话最好的什么类型,我用的是datetime
追答
你看看计算结果21836是什么值就知道该用什么类型了。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式