首页 > 解决方案 > 为什么在 Workbench 中有效的 MySql 查询在 phpmyadmin 中返回语法错误?

问题描述

所以我在 2 个不同的数据库中作为 id_information 和 id_information_backup 有 2 个表作为 table1 和 table2。两个表都有以下列: (id bigint, name varchar, surname varchar) 我做了这个触发器,当用户在 table1 中输入姓名和姓氏时,它会计算它的 ascii 代码并进行一些计算并将其存储在“第二个表的名称”列,即“table2”。所有这些都在 Mysql 工作台中完成。当我将代码导入 phpmyadmin 时,它给了我太多的语法错误。我试图弄清楚我有什么语法错误,但我找不到。我在下面分享触发器。如果可以的话,请帮助我。我会很感激的。我想这是因为我使用的版本是 MySQL workbench 8.0 而我要导入的版本是 PHPmyadmin 4.9.4 。

delimiter $$ 
CREATE DEFINER = CURRENT_USER TRIGGER `id_information`.`table1_after_INSERT1` AFTER INSERT ON `table1` FOR EACH ROW
BEGIN
declare p , r , copy, result, result1 decimal(64,0);
declare name1, surnam varchar(15);
declare a int;
set name1 = new.name;
set surnam = new.surname;
set a= 100;
set result =0;
set copy = 0;
set result1 =0;
set p =0 ;
set r =0 ;
with recursive cte as (
    select name1 as name1, left(name1, 1) as val, 1 as idx
    union all
    select name1, substring(name1, idx + 1, 1), idx + 1 
    from cte 
    where idx < char_length(name1)
)
select group_concat(ascii(val) + a order by idx separator '') ascii_word from cte into result;
with recursive ctee as (
    select surnam as surnam, left(surnam, 1) as vall , 1 as idxx
    union all
    select surnam, substring(surnam, idxx+ 1, 1), idxx+ 1 
    from ctee
    where idxx< char_length(surnam)
)
select group_concat(ascii(vall )  + a order by idxx separator '') ascii_word from ctee into result1;
select group_concat(result, result1) into copy;
insert into id_information_backup.table2  set table2.name = copy;
END$$
delimiter ;

标签: mysqltriggersphpmyadminmysql-workbenchversion

解决方案


当您尝试运行命令时(通过按下 SQL 文本区域底部的“开始”按钮),会发生什么?

如果 phpMyAdmin 在提交之前将错误显示为 SQL 区域左侧带有白色x的红色圆圈,那么这些是语法警告,不会影响您提交查询的能力。这些是 phpMyAdmin 中的 SQL linter 作为提示提供的。

phpMyAdmin 语法警告: phpMyAdmin 语法警告

如果错误是在提交语句之后出现的,那么错误来自 MySQL 本身,而不是由 phpMyAdmin 直接引起的。

MySQL 语法错误: MySQL 语法错误


推荐阅读