MySQL Stored Procedure learning summary, MySQL CREATE procedure, MySQL-related stored procedure function usage!
 
MySQL 5.0 Stored Procedure learning Summary
 
Create, delete, and call MySQL stored procedures and other common commands
 
MySQL 5.0 Stored Procedure learning Summary
 
1. Create a stored procedure
 
1. Basic Syntax: Create procedure sp_name ()
Begin
.........
End
 
2. parameter transfer
 
Ii. Call the Stored Procedure
 
1. Basic Syntax: Call sp_name ()
Note: The stored procedure name must be enclosed in parentheses, even if the stored procedure has no parameters
 
Iii. delete stored procedures
 
1. Basic Syntax:
Drop procedure sp_name //
2. Notes
(1) You cannot delete another stored procedure in one stored procedure. You can only call another stored procedure.
 
4. blocks, conditions, and loops
 
1. Block definition, commonly used
Begin
......
End;
You can also create an alias for the block, such:
Lable: Begin
...........
End lable;
You can use leave lable to jump out of the block and execute code after the block.
2. conditional statement if condition then
Statement
Else
Statement
End if;
 
3. Loop statements
(1). While Loop
 
[Label:] While expression do
Statements
End while [label];
(2) loop [label:] Loop
Statements
End loop [label]; (3). Repeat until loop [label:] Repeat
Statements
Until expression
End repeat [label];
 
5. Other Common commands
 
1. Show procedure status
Displays basic information about all stored procedures in the database, including the database, stored procedure name, and creation time.
2. Show create procedure sp_name
Displays detailed information about a stored procedure.
 
Operators used in MySQL stored procedures
 
MySQL Stored Procedure learning Summary-Operators
 
Arithmetic Operators
 
+ Add set var1 = 2 + 2; 4
-Subtract set var2 = 3-2; 1
* Multiply by set var3 = 3*2; 6
/Except set var4 = 10/3; 3.3333
Div Division set var5 = 10 Div 3; 3
% Modulo set var6 = 10% 3; 1
 
Comparison Operators
 
> Greater than 1> 2 false
<Less than 2 <1 false
<= Less than or equal to 2 <= 2 true
>=Greater than or equal to 3> = 2 true
Between is 5 between two values between 1 and 10 true
Not between not between two values 5 not between 1 and 10 false
In the set, 5 in (,) is false.
Not in is not in the set 5 not in (,) True
= Equal to 2 = 3 false
<> ,! = Not equal to 2 <> 3 false
<=> Strictly compare whether two null values are equal null <=> null true
Like simple pattern matching "guy Harrison" like "guy %" true
Regexp regular expression match "guy Harrison" Regexp "[Gg] Reg" false
Is null is null 0 is null false
Is not null 0 is not null true
 
Logical operators
 
And(And) True
 
Or (OR)
 
Exclusive or (XOR)
 
Bitwise operators
 
| Bit or
& Bit and
<Left shift
> Right shift
~ Bitwise non (single object operation, bitwise inversion)
 
 
 
Common functions in mysq stored procedures, string operations, mathematics, and date and time.
 
MySQL stored procedure basic functions
 
I. string type
 
Charset (STR) // returns the string Character Set
Concat (string2 [,...]) // connection string
Instr (string, substring) // returns the position of the first occurrence of the substring in the string. If no position exists, 0 is returned.
Lcase (string2) // converts it to lowercase
Left (string2, length) // take the length from the left of string2
Length (string) // String Length
Load_file (file_name) // read content from the file
Locate (substring, string [, start_position]) is the same as instr, but the start position can be specified.
Lpad (string2, length, pad) // repeat pad to start with string until the string length is length
Ltrim (string2) // remove leading Spaces
Repeat (string2, count) // repeat count times
Replace (STR, search_str, replace_str) // replace search_str with replace_str in Str
Rpad (string2, length, pad) // use pad after STR until the length is length.
Rtrim (string2) // remove backend Spaces
Strcmp (string1, string2) // compare the size of two strings by character,
Substring (STR, position [, length]) // starts from the position of STR and takes length characters,
Note: When processing strings in MySQL, the default subscript of the first character is 1, that is, the position parameter must be greater than or equal to 1 mysql> select substring ('abcd );
+ -------- +
| Substring ('abcd',) |
+ -------- +
|
+ -------- +
1 row in SET (0.00 Sec) mysql> select substring ('abc );
+ -------- +
| Substring ('abcd', 1, 2) |
+ -------- +
| AB |
+ -------- +
1 row in SET (0.02 Sec)
 
Trim ([[Both | leading | trailing] [Padding] From] string2) // remove the specified character from the specified position
Ucase (string2) // converts to uppercase
Right (string2, length) // gets the last length character of string2
Space (count) // generate count Spaces
 
Ii. Mathematics
 
ABS (number2) // absolute value
Bin (decimal_number) // convert decimal to binary
Ceiling (number2) // rounded up
Conv (number2, from_base, to_base) // hexadecimal conversion
Floor (number2) // round down
Format (number, decimal_places) // number of reserved decimal places
Hex (decimalnumber) // convert to hexadecimal
Note: Hex () can input a string, returns its ASC-11 code, such as hex ('def ') returns 4142143
You can also input a decimal integer to return its hexadecimal encoding. For example, Hex (25) returns 19.
Least (number, number2 [,...]) // calculates the minimum value.
MoD (numerator, denominator) // evaluate the remainder
Power (number, power) // Exponent
Rand ([seed]) // Random Number
Round (number [, decimals]) // rounding, decimals is decimal places] Note: The return type is not an integer, for example:
(1) The default value is integer.
Mysql> select round (1.23 );
+ ----- +
| Round (1.23) |
+ ----- +
| 1 |
+ ----- +
1 row in SET (0.00 Sec)
 
Mysql> select round (1.56 );
+ ----- +
| Round (1.56) |
+ ----- +
| 2 |
+ ----- +
1 row in SET (0.00 Sec)
 
(2) the number of decimal places can be set to return floating point data.
Mysql> select round (1.567, 2 );
+ ------ +
| Round (1.567, 2) |
+ ------ +
| 1, 1.57 |
+ ------ +
1 row in SET (0.00 Sec)
 
Sign (number2) // return sign, positive and negative or 0
SQRT (number2) // Square
 
 
Iii. Date and Time
 
 
Addtime (date2, time_interval) // Add time_interval to date2
Convert_tz (datetime2, fromtz, totz) // convert the time zone
Current_date () // current date
Current_time () // current time
Current_timestamp () // current Timestamp
Date (datetime) // return the date part of datetime
Date_add (date2, interval d_value d_type) // Add a date or time in date2
Date_format (datetime, formatcodes) // display datetime in formatcodes format
Date_sub (date2, interval d_value d_type) // subtract a time from date2
Datediff (date1, date2) // two date differences
Day (date) // returns the day of the date
Dayname (date) // english week
Dayofweek (date) // Week (1-7), 1 is Sunday
Dayofyear (date) // The day of the year
Extract (interval_name from date) // extract the specified part of the date from date
Makedate (year, day) // specifies the day of the year and year to generate a date string.
Maketime (hour, minute, second) // generate a time string
Monthname (date) // name of the English month
Now () // current time
Sec_to_time (seconds) // converts seconds to time
Str_to_date (string, format) // convert string to time, which is displayed in format
Timediff (datetime1, datetime2) // two time difference
Time_to_sec (time) // time to seconds]
Week (date_time [, start_of_week]) // week
Year (datetime) // year
Dayofmonth (datetime) // The day of the month
Hour (datetime) // hour
Last_day (date) // the last date of the Month of date
Microsecond (datetime) // microsecond
Month (datetime) // month
Minute (datetime) // minute
 
 
 
Appendix: available types in interval
Day, day_hour, day_minute, day_second, hour, hour_minute, hour_second, minute, minute_second, month, second, year
 
Delimiter $ # update the balance and cash fields of order line consumption drop procedure if exists fix_cl_consumption_balence_related $ create procedure transaction (in cl_id bigint (20), In mydate datetime, cost decimal (12, 2), cash decimal (12, 2) Begin declare no_more_ SQL int default 0; declare temp_id bigint (20); declare counter int default 0; declare SQL _cur cursor for select CC. ID from contract_line_consumption CC where CC. 'Contract _ line_id '= cl_id and CC. 'date'> = mydate order by CC. date ASC; declare continue handler for not found set no_more_ SQL = 1; open SQL _cur; repeat fetch SQL _cur into temp_id; if not no_more_ SQL then update contract_line_consumption CC set CC. balance = cc. balance-cost, CC. balance_cash = cc. balance_cash-cash Where CC. id = temp_id; set counter = counter + 1; end if; until no_more_ SQL end repeat; close SQL _cur; end $ # update the cost, cost_cash, amount_availabe and cash_availabledrop procedure if exists partition $ create procedure partition (in cl_id bigint (20), in cost decimal (12, 2), in cash decimal (12, 2 )) begin declare no_more_ SQL int default 0; declare I _id bigint (20); declare alias decimal (12, 2); declare I _cash_available decimal (12, 2); declare I _cost decimal (12, 2); declare I _cost_cash decimal (12, 2); declare I _ratio decimal (12, 5); declare temp_cost_cash decimal (12, 2); declare temp_amount decimal (12, 2 ); declare SQL _cur cursor for select RR. ID, RR. amount_available, RR. cash_available, RR. cost, RR. cost_cash, RR. ratio from recharge_record RR where RR. contract_line_id = cl_id order by RR. recharge_time ASC; declare continue handler for not found set amount = 1; Set temp_amount = cost; open SQL _cur; repeat fetch SQL _cur into I _id, expires, expires, I _cost, expires, I _ratio; if not no_more_ SQL then if limit> 0 & I _cash_available> 0 then if temp_amount <> 0 then if temp_amount> = then set temp_amount = temp_amount-limit; update recharge_record RR set rr. cost = RR. amount, RR. cost_cash = RR. cash where RR. id = I _id; update recharge_record RR set RR. amount_available = 0, RR. cash_available = 0 where RR. id = I _id; else set temp_cost_cash = temp_amount * I _ratio; update recharge_record RR set RR. cost = RR. cost + temp_amount, RR. cost_cash = RR. cost_cash + temp_cost_cash, RR. amount_available = RR. amount_available-temp_amount, RR. cash_available = RR. cash_available-temp_cost_cash where RR. id = I _id; Set temp_amount = 0; end if; until no_more_ SQL end repeat; close SQL _cur; end $ drop procedure if exists partition $ create procedure partition (in I _adc_id bigint (20), In I _cost decimal (12, 2), In I _cash decimal (12, 2 ), in I _date datetime, in I _cl_id bigint (20) begin # Fix the cost of ad_consumption, cash update ad_consumption set cost = I _cost, Cash = I _cash where id = I _adc_id; # update contract_line_consumption cost and cash update contract_line_consumption AC inner join (select sum (WC. 'cost') as cost, sum (WC. 'cash ') as cash, WC. 'Contract _ line_id 'As contract_line_id from ad_consumption WC where WC. 'Contract _ line_id '= I _cl_id and WC. 'date' = I _date group by WC. 'Contract _ line_id ') XX on xx. 'Contract _ line_id '= ac. 'Contract _ line_id 'set AC. cost = xx. cost, AC. cash = xx. cash where AC. 'date' = I _date; # update the balance and balence_cash of the order line (0 before CC) Update contract_line Cl inner join contract_line_consumption CC on CC. 'Contract _ line_id '= Cl. 'Contract _ line_id 'and CC. date = I _date set Cl. 'balance '= Cl. 'balance '-CC. 'cost', cl. 'balance _ cash '= Cl. 'balance _ cash '-CC. 'cash 'Where Cl. 'Contract _ line_id '= I _cl_id; # update the balance and cash field call balance (I _cl_id, I _date, I _cost, I _cash) of the Order line; # update the cost, cost_cash, amount_availabe and cash_available call sequence (I _cl_id, I _cost, I _cash); End $ delimiter; Call Sequence (341479,265 4, 2654/2, '2017-01-15 ', 2013 ); drop procedure if exists fix_cl_consumption_balence_related; drop procedure if exists exist; drop procedure if exists fix_consumption_from_botton_to_top;