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)热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语