安装组件时创建mysql函数

时间:2013-12-03 12:28:41

标签: mysql sql joomla joomla2.5

我想在我的Joomla 2.5组件安装程序中包含mysql函数的创建。这是功能:

DELIMITER $$

DROP FUNCTION IF EXISTS getDistance $$


CREATE FUNCTION `getDistance` (
    lat1 DECIMAL( 18, 12 ) ,
    lng1 DECIMAL( 18, 12 ) ,
    lat2 DECIMAL( 18, 12 ) ,
    lng2 DECIMAL( 18, 12 )
    ) 
    RETURNS DECIMAL( 18, 12 ) DETERMINISTIC 

BEGIN 
DECLARE `distance` DECIMAL( 18, 12 ) ;

SELECT ( 
    6371 * 
    acos( cos( radians( lat1 ) ) * 
    cos( radians( lat2 ) ) * 
    cos( 
        radians( lng2 ) - radians( lng1 ) ) + 
    sin( radians( lat1 ) ) * 
    sin( radians( lat2 ) ) ) )
INTO `distance`;

RETURN `distance`;

END $$

DELIMITER ;

如果我使用网站用户和密码登录phpmyadmin,则可以正常创建该函数。

我试过了:

  • 将其插入创建表的.sql文件中,
  • 从安装后脚本运行它(我可以处理错误的首选方法)
  • 从管理工具栏中的按钮
  • 运行
  • 使用不同的分隔符:£
  • 用#__距离替换距离标识符

没有工作。

sql文件是utf8,没有bom。

如果我使用sql安装程序,则显示两次错误:

JInstaller: :Install: Error SQL DB function failed with error number 1327
Undeclared variable: distance SQL=SELECT ( 6371 * acos( cos( radians( lat1 ) ) * cos( radians( lat2 ) ) * cos( radians( lng2 ) - radians( lng1 ) ) + sin( radians( lat1 ) ) * sin( radians( lat2 ) ) ) ) INTO `distance`;
SQL =

SELECT ( 
    6371 * 
    acos( cos( radians( lat1 ) ) * 
    cos( radians( lat2 ) ) * 
    cos( 
        radians( lng2 ) - radians( lng1 ) ) + 
    sin( radians( lat1 ) ) * 
    sin( radians( lat2 ) ) ) )
INTO `distance`;

如果我从组件的控制器中运行它,这是我查询$ db-> getErrorMsg()的错误。

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DELIMITER ££' at line 1 SQL=DELIMITER ££ DROP FUNCTION IF EXISTS getDistance ££ CREATE FUNCTION `xxyx_getDistance` ( lat1 DECIMAL( 18, 12 ) , lng1 DECIMAL( 18, 12 ) , lat2 DECIMAL( 18, 12 ) , lng2 DECIMAL( 18, 12 ) ) RETURNS DECIMAL( 18, 12 ) DETERMINISTIC BEGIN DECLARE `xxyx_distance` DECIMAL( 18, 12 ) ; SELECT ( 6371 * acos( cos( radians( lat1 ) ) * cos( radians( lat2 ) ) * cos( radians( lng2 ) - radians( lng1 ) ) + sin( radians( lat1 ) ) * sin( radians( lat2 ) ) ) ) INTO `xxyx_distance`; RETURN `xxyx_distance`; END ££ DELIMITER ;

1 个答案:

答案 0 :(得分:1)

DELIMITER是一个客户端构造,告诉客户端语句的结尾,而不是服务器。

如果你创建一个字符串,其中包含从“CREATE FUNCTION”到函数定义的最后“END”的所有内容......没有“DELIMITER”语句,并且在“END”之后不需要“$$”或其他符号“...并执行该字符串作为对您的连接对象的查询,服务器应该理解它。同样的事情是“DROP FUNCTION IF EXISTS function_name”,首先执行。