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)热门推荐
3 孙媳妇祝福语简短
10 庆祝国家的祝福语简短
11 写给兄弟的祝福语简短
12 祝贺新店开业祝福语简短
13 餐前仪式祝福语简短
14 请灵回向祝福语简短
15 祝福语女友文案简短霸气
16 牛年佛家祝福语大全简短
17 母亲说生日祝福语 简短
18 新年简短的英文祝福语