mysql创建函数但它已经存在

时间:2016-08-17 01:20:37

标签: mysql

MYSQL Server版本:5.1.73源代码分发。

我无法创建功能,它在放弃之后仍然存在。

首先删除功能

mysql> drop function if exists `xapps_f20160817`;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> show warnings;
+-------+------+-----------------------------------------+
| Level | Code | Message                                 |
+-------+------+-----------------------------------------+
| Note  | 1305 | FUNCTION xapps_f20160817 does not exist |
+-------+------+-----------------------------------------+
1 row in set (0.00 sec)

但是当我再次创建它时它仍然存在。

mysql> create function `xapps_f20160817`(
    -> `_time` varchar(30),
    -> `_rpid` varchar(10),
    -> `_mvsz` varchar(10),
    -> `_rvsz` varchar(10),
    -> `_ncpu` varchar(10),
    -> `_rcpu` varchar(10),
    -> `_appn` varchar(64)
    -> )  RETURNS BIGINT READS SQL DATA
    -> BEGIN
    -> insert into `20160817`(time, rpid, mvsz, rvsz, ncpu, rcpu, appn)
    -> values(_time, _rpid, _mvsz, _rvsz, _ncpu, _rcpu, _appn);
    -> RETURN LAST_INSERT_ID();
    -> END
ERROR 1304 (42000): FUNCTION xapps_f20160817 already exists

尝试使用:

mysql> select xapps_f20160817('100','100','100','100','100','100','100');$$
ERROR 1305 (42000): FUNCTION xapps_db.xapps_f20160817 does not exist

尝试从功能列表中找到它:

mysql> show function status where name='xapps_f20160817';$$
Empty set (0.00 sec)

尝试删除它,但它不存在:

mysql> drop function if exists `xapps_f20160817`;$$
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> show warnings;$$
+-------+------+-----------------------------------------+
| Level | Code | Message                                 |
+-------+------+-----------------------------------------+
| Note  | 1305 | FUNCTION xapps_f20160817 does not exist |
+-------+------+-----------------------------------------+
1 row in set (0.01 sec)

是mysql的错误吗? 如何正确删除此功能? ps:跳过不重要的语法。

1 个答案:

答案 0 :(得分:2)

确保您拥有来自use mydbname;

的选定数据库
DROP FUNCTION IF EXISTS myfunc789a;
DELIMITER $$
create function myfunc789a
(   theI INT
)
RETURNS INT
BEGIN
    RETURN theI*7;
END$$
DELIMITER ;

select myfunc789a(8);

DELIMITER仅用于某些客户端工具。不是phpmyadmin。

avec反击,没问题5.6 5.7:

DROP FUNCTION IF EXISTS `myfunc789a`;
DELIMITER $$
create function `myfunc789a`
(   theI INT
)
RETURNS INT
BEGIN
    RETURN theI*7;
END$$
DELIMITER ;

select `myfunc789a`(8);

Bug # 16303

enter image description here