mysql命令行客户端机的分隔符,如果你使用的是mysql命令行实用程序,应该仔细的阅读此说明。
默认的mysql语句分隔符为;(正如你已经在迄今为止所使用的mysql语句中所有看到的那样)。mysql命令行实用程序也是使用;作为语句分隔符。如果命令行实用程序要解释存储过程自身内的;字符,则它们最终不会成为存储过程的成分,这样使存储过程中的sql出现语法错误。
解决办法是临时更改命令行实用程序的语句分隔符,如下所示:
delimiter //
create procedure procl()
begin
select intersectionunit as '路口单位',intersectionname as '路口名称',drivedirection as '行车方向',scar+mcar+bcar as '总流量' from alllntersection;
end //
delimiter;
其中,delimiter //告诉命令行实用程序实用//作为新的语句结束分隔符,可以看到标志存储过程结束的end定义为end//而不是end;。这样,存储过程体内的;仍然保持不动,并且正确地传递数据库引擎。最后,为恢复为原来的语句分隔符,可以使用delimiter;。除/符号外,任何字符都可以用作语句分隔符。
如果你使用的是mysql命令行实用程序!切记切记!
下图是表alllntersection对他做了存储!
删除存储过程:
drop procedure procl ;