MySQL在创建存储过程时是否保留环境?

实际上,MySQL在创建存储过程时会保留环境。可以通过下面的示例来理解,在该示例中,我们使用两个条形连接字符串。仅当SQL模式为ansi时这才合法。但是,如果我们将SQL模式更改为non-ansi,则该过程仍然会像原始设置一样运行。

示例

mysql> Set sql_mode = 'ansi'//

mysql> Create Procedure Con_string()
    -> SELECT 'a'||'b'//
mysql> Call Con_string ();
+----------+
| 'a'||'b' |
+----------+
| ab       |
+----------+
1 row in set (0.05 sec)

mysql> Set sql_mode = '';

mysql> Call Con_string();
+----------+
| 'a'||'b' |
+----------+
| ab       |
+----------+
1 row in set (0.00 sec)

上面的结果集显示,即使将SQL模式更改为non-ansi之后,过程Con_string()仍会产生与SQL模式仍然为ansi相同的结果。但是新过程将不接受两个小节,因为我们已将SQL模式更改为non-ansi。

mysql> create procedure Con_string1()
    -> Select 'a'||'b'//

mysql> Call Con_string1()//
+----------+
| 'a'||'b' |
+----------+
|        0 |
+----------+
1 row in set (0.00 sec)
猜你喜欢