Mysql中“=”与“:=“的区别

在学习如何定义一个存储过程中,由于我没有理解**=:=**的本质,结果再运行的过程中一直报语法错误,调试的过程不得其法,现总结如下:

一般情况:
在mysql中,**=就是等于的意思,它表示符号左右值相等,而:=**表示赋值,例如假定一个变量a,初始对a赋值为1,对于等式a=2,它是一个判断语句,表示a是否等于2,结果为布尔值;对于a:=2,它表示对a重新赋值,这时a的值变成了2.

特殊情况
但是在set和update语法下,**=**代表了赋值,例如对变量a赋值,
set a=1 和 a:=1 效果一样。

你可能感兴趣的:(芝麻错误,mysql,sql)