You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@shardingsphere.apache.org by du...@apache.org on 2023/02/10 08:58:58 UTC

[shardingsphere] branch master updated: Fix mysql create procedure syntax error. (#24100)

This is an automated email from the ASF dual-hosted git repository.

duanzhengqiang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/shardingsphere.git


The following commit(s) were added to refs/heads/master by this push:
     new db812fd47f5 Fix mysql create procedure syntax error. (#24100)
db812fd47f5 is described below

commit db812fd47f52c4d2971f3756f5827bff666057c5
Author: Chuxin Chen <ch...@qq.com>
AuthorDate: Fri Feb 10 16:58:51 2023 +0800

    Fix mysql create procedure syntax error. (#24100)
---
 .../dialect/mysql/src/main/antlr4/imports/mysql/DDLStatement.g4       | 4 ++--
 test/it/parser/src/main/resources/case/ddl/create-procedure.xml       | 1 +
 .../parser/src/main/resources/sql/supported/ddl/create-procedure.xml  | 1 +
 3 files changed, 4 insertions(+), 2 deletions(-)

diff --git a/sql-parser/dialect/mysql/src/main/antlr4/imports/mysql/DDLStatement.g4 b/sql-parser/dialect/mysql/src/main/antlr4/imports/mysql/DDLStatement.g4
index 6ec2751ee72..434492c31be 100644
--- a/sql-parser/dialect/mysql/src/main/antlr4/imports/mysql/DDLStatement.g4
+++ b/sql-parser/dialect/mysql/src/main/antlr4/imports/mysql/DDLStatement.g4
@@ -17,7 +17,7 @@
 
 grammar DDLStatement;
 
-import DMLStatement, DALStatement;
+import DMLStatement, DALStatement, TCLStatement;
 
 alterStatement
     : alterTable
@@ -665,7 +665,7 @@ compoundStatement
 validStatement
     : (createTable | alterTable | dropTable | truncateTable 
     | insert | replace | update | delete | select | call
-    | createView
+    | createView | prepare | executeStmt | commit | deallocate
     | setVariable | beginStatement | declareStatement | flowControlStatement | cursorStatement | conditionHandlingStatement) SEMI_?
     ;
 
diff --git a/test/it/parser/src/main/resources/case/ddl/create-procedure.xml b/test/it/parser/src/main/resources/case/ddl/create-procedure.xml
index 4356dc3a684..d10b129fc18 100644
--- a/test/it/parser/src/main/resources/case/ddl/create-procedure.xml
+++ b/test/it/parser/src/main/resources/case/ddl/create-procedure.xml
@@ -31,4 +31,5 @@
     <create-procedure sql-case-id="create_procedure_with_sqlexception_and_create_view" />
     <create-procedure sql-case-id="create_procedure_with_deterministic_create_view" />
     <create-procedure sql-case-id="create_procedure_with_update_statement_oracle" />
+    <create-procedure sql-case-id="create_procedure_with_prepare_commit" />
 </sql-parser-test-cases>
diff --git a/test/it/parser/src/main/resources/sql/supported/ddl/create-procedure.xml b/test/it/parser/src/main/resources/sql/supported/ddl/create-procedure.xml
index a6dd6e1471f..44ae735dbb1 100644
--- a/test/it/parser/src/main/resources/sql/supported/ddl/create-procedure.xml
+++ b/test/it/parser/src/main/resources/sql/supported/ddl/create-procedure.xml
@@ -43,4 +43,5 @@
     <sql-case id="create_procedure_with_sqlexception_and_create_view" value="create procedure p() begin declare continue handler for sqlexception begin end; create view a as select 1; end" db-types="MySQL" />
     <sql-case id="create_procedure_with_deterministic_create_view" value="create procedure p1 () deterministic begin create view v1 as select 1; end;" db-types="MySQL" />
     <sql-case id="create_procedure_with_update_statement_oracle" value="CREATE PROCEDURE update_order (order_id NUMBER,status NUMBER) AS BEGIN  UPDATE t_order SET status = status WHERE order_id = order_id;END;" db-types="Oracle" />
+    <sql-case id="create_procedure_with_prepare_commit" value="CREATE DEFINER=`sys_data`@`%` PROCEDURE `TEST1` (a VARCHAR(64),b VARCHAR(64),c VARCHAR(64),d VARCHAR(8),e INT) BEGIN DECLARE f VARCHAR(8); SET f=DATE_FORMAT(DATE_ADD((STR_TO_DATE(d,'%Y%m%d')),INTERVAL -(e) MONTH),'%Y%m%d'); SET @aaa=CONCAT('delete from ',a,'.',b,' where ',c,'&lt;=',f,' or ', c,'&lt;&gt; LAST_DAY(',c,')', 'or ',c,'=', d); PREPARE stmt FROM @aaa; EXECUTE stmt; COMMIT; DEALLOCATE PREPARE stmt; END" db-types="MySQL" />
 </sql-cases>