Navicat cannot create function solution sharing

Navicat cannot create function solution sharing

The first time I wrote a MySQL FUNCTION, I kept getting errors.

Err] 1064 - 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 '`company_id` int) RETURNS varchar(20) CHARSET utf8

BEGIN

The original function:

CREATE DEFINER=`33323`@`%` FUNCTION `createSaleCode`(`benginStr` varchar,`company_id` int) RETURNS varchar(20) CHARSET utf8 
BEGIN 
  DECLARE nearnum VARCHAR(20);  
 DECLARE nowdatepre VARCHAR(20); 
 DECLARE numout VARCHAR(20);  
 SELECT a.sale_code INTO nearnum FROM d_sale a WHERE a.company_id = company_id ORDER BY a.sale_id DESC limit 1; 
 SELECT concat(extract(year_month from now()),LPAD(extract(day from now()), 2, 0)) INTO nowdatepre; 
 IF locate(nowdatepre,nearnum)>0  
  THEN  
    set numout = nearnum +1;   
  ELSE  
    set numout = concat(beginStr,nowdatepre,'00001');  
  END IF; 
 RETURN numout; 
END

This function cannot be executed on Navicat. After several attempts, the code is modified to the following:

delimiter $$ 
CREATE DEFINER=`12212`@`%` FUNCTION createSaleCode(benginStr varchar(20),company_id int(11) ) RETURNS varchar(20) CHARSET utf8 
BEGIN 
  DECLARE nearnum VARCHAR(20);  
 DECLARE nowdatepre VARCHAR(20); 
 DECLARE numout VARCHAR(20);  
 SELECT a.sale_code INTO nearnum FROM d_sale a WHERE a.company_id = company_id ORDER BY a.sale_id DESC limit 1; 
 SELECT concat(extract(year_month from now()),LPAD(extract(day from now()), 2, 0)) INTO nowdatepre; 
 IF locate(nowdatepre,nearnum)>0  
  THEN  
    set numout = nearnum +1;   
  ELSE  
    set numout = concat(beginStr,nowdatepre,'00001');  
  END IF; 
 RETURN numout; 
END$$ 
delimiter ;

Problem solved.

By default, the delimiter is a semicolon;.

Summarize

The above is all the content of this article about the solution to the problem that navicat cannot create functions. I hope it will be helpful to everyone. Interested friends can continue to refer to this site: a brief introduction to the difference between Redis and MySQL, analysis of MYSQL subquery and nested query optimization examples, several important MySQL variables, etc. If you have any questions, you can leave a message at any time and the editor will reply to you in time. Thank you friends for supporting this site!

You may also be interested in:
  • Simple examples of creating stored procedures, triggers and using cursors in Navicat (pictures and text)
  • Navicat 8 creates a database and creates a user to assign permissions graphic method
  • Use Navicat 8 to create a database and import data to manage users and permissions [Graphic Method]

<<:  VMware Workstation 14 Pro installation Ubuntu 16.04 tutorial

>>:  How to clean up Alibaba Cloud MySQL space

Recommend

Summary of experience in using div box model

Calculation of the box model <br />Margin + ...

Detailed explanation of MySQL information_schema database

1. Overview The information_schema database is th...

Implementing a simple carousel based on JavaScript

This article shares the specific code of JavaScri...

Docker packages the local image and restores it to other machines

1. Use docker images to view all the image files ...

CSS writing format, detailed explanation of the basic structure of a mobile page

1. CSS writing format 1. Inline styles You can wr...

echars 3D map solution for custom colors of regions

Table of contents question extend Solving the pro...

Detailed explanation of global parameter persistence in MySQL 8 new features

Table of contents Preface Global parameter persis...

Take you to a thorough understanding of the prototype object in JavaScript

Table of contents 1. What is a prototype? 1.1 Fun...

JavaScript to achieve balance digital scrolling effect

Table of contents 1. Implementation Background 2....

JS thoroughly understands GMT and UTC time zones

Table of contents Preface 1. GMT What is GMT Hist...

Sample code for a large drop-down menu implemented in pure CSS

This is a large drop-down menu implemented purely...

Detailed example of mysql trigger usage

MySQL trigger syntax details: A trigger is a spec...

CSS implements the web component function of sliding the message panel

Hello everyone, I wonder if you have the same con...

PostgreSQL materialized view process analysis

This article mainly introduces the process analys...

Windows system mysql5.7.18 installation graphic tutorial

MySQL installation tutorial for Windows system do...