欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL存储过程中的基本函数和触发器的相关学习教程

程序员文章站 2024-02-26 17:02:40
mysql存储过程的常用函数 一.字符串类 charset(str) //返回字串字符集 concat (string2 [,... ]) //连接字串 inst...

mysql存储过程的常用函数

一.字符串类
charset(str) //返回字串字符集
concat (string2 [,... ]) //连接字串
instr (string ,substring ) //返回substring首次在string中出现的位置,不存在返回0
lcase (string2 ) //转换成小写
left (string2 ,length ) //从string2中的左边起取length个字符
length (string ) //string长度
load_file (file_name ) //从文件读取内容
locate (substring , string [,start_position ] ) 同instr,但可指定开始位置
lpad (string2 ,length ,pad ) //重复用pad加在string开头,直到字串长度为length
ltrim (string2 ) //去除前端空格
repeat (string2 ,count ) //重复count次
replace (str ,search_str ,replace_str ) //在str中用replace_str替换search_str
rpad (string2 ,length ,pad) //在str后用pad补充,直到长度为length
rtrim (string2 ) //去除后端空格
strcmp (string1 ,string2 ) //逐字符比较两字串大小,
substring (str , position [,length ]) //从str的position开始,取length个字符,
注:mysql中处理字符串时,默认第一个字符下标为1,即参数position必须大于等于1

mysql> select substring('abcd',0,2);

+-----------------------+
| substring('abcd',0,2) |
+-----------------------+
| |
+-----------------------+
1 row in set (0.00 sec)


mysql> select substring('abcd',1,2);
+-----------------------+
| substring('abcd',1,2) |
+-----------------------+
| ab |
+-----------------------+
1 row in set (0.02 sec)

trim([[both|leading|trailing] [padding] from]string2) //去除指定位置的指定字符
ucase (string2 ) //转换成大写
right(string2,length) //取string2最后length个字符
space(count) //生成count个空格

二.数学类

abs (number2 ) //绝对值
bin (decimal_number ) //十进制转二进制
ceiling (number2 ) //向上取整
conv(number2,from_base,to_base) //进制转换
floor (number2 ) //向下取整
format (number,decimal_places ) //保留小数位数
hex (decimalnumber ) //转十六进制
注:hex()中可传入字符串,则返回其asc-11码,如hex('def')返回4142143
也可以传入十进制整数,返回其十六进制编码,如hex(25)返回19
least (number , number2 [,..]) //求最小值
mod (numerator ,denominator ) //求余
power (number ,power ) //求指数
rand([seed]) //随机数
round (number [,decimals ]) //四舍五入,decimals为小数位数]
注:返回类型并非均为整数,如:
(1)默认变为整形值

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)可以设定小数位数,返回浮点型数据

mysql> select round(1.567,2);
+----------------+
| round(1.567,2) |
+----------------+
| 1.57 |
+----------------+
1 row in set (0.00 sec)

sign (number2 ) //返回符号,正负或0
sqrt(number2) //开平方


三.日期时间类

addtime (date2 ,time_interval ) //将time_interval加到date2
convert_tz (datetime2 ,fromtz ,totz ) //转换时区
current_date ( ) //当前日期
current_time ( ) //当前时间
current_timestamp ( ) //当前时间戳
date (datetime ) //返回datetime的日期部分
date_add (date2 , interval d_value d_type ) //在date2中加上日期或时间
date_format (datetime ,formatcodes ) //使用formatcodes格式显示datetime
date_sub (date2 , interval d_value d_type ) //在date2上减去一个时间
datediff (date1 ,date2 ) //两个日期差
day (date ) //返回日期的天
dayname (date ) //英文星期
dayofweek (date ) //星期(1-7) ,1为星期天
dayofyear (date ) //一年中的第几天
extract (interval_name from date ) //从date中提取日期的指定部分
makedate (year ,day ) //给出年及年中的第几天,生成日期串
maketime (hour ,minute ,second ) //生成时间串
monthname (date ) //英文月份名
now ( ) //当前时间
sec_to_time (seconds ) //秒数转成时间
str_to_date (string ,format ) //字串转成时间,以format格式显示
timediff (datetime1 ,datetime2 ) //两个时间差
time_to_sec (time ) //时间转秒数]
week (date_time [,start_of_week ]) //第几周
year (datetime ) //年份
dayofmonth(datetime) //月的第几天
hour(datetime) //小时
last_day(date) //date的月的最后日期
microsecond(datetime) //微秒
month(datetime) //月
minute(datetime) //分


附:可用在interval中的类型
day ,day_hour ,day_minute ,day_second ,hour ,hour_minute ,hour_second ,minute ,minute_second,month ,second ,year

 mysql存储过程和触发器
1.创建存储过程

delimiter //
drop procedure if exists `proc_test`//
create procedure `proc_test`(table_name varchar(20),num int)
begin
  select * from table_name limit num;
end//
delimiter ;

调用存储过程:

call proc_test('user',20);

删除存储过程:

drop procudure productpricing

2.创建触发器
~~语法~~
create trigger <触发器名称> --触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和mysql中其他对象的命名方式基本相象.
{ before | after } --触发器有执行的时间设置:可以设置为事件发生前或后。
{ insert | update | delete } --同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。
on <表名称> --触发器是属于某一个表的:当在这个表上执行插入、 更新或删除操作的时候就导致触发器的激活. 我们不能给同一张表的同一个事件安排两个触发器。
for each row --触发器的执行间隔:for each row子句通知触发器 每隔一行执行一次动作,而不是对整个表执行一次。
<触发器sql语句> --触发器包含所要触发的sql语句:这里的语句可以是任何合法的语句, 包括复合语句,但是这里的语句受的限制和函数的一样。

--你必须拥有相当大的权限才能创建触发器(create trigger),如果你已经是root用户,那么就足够了。这跟sql的标准有所不同。
 
创建触发器:t_afterinsert_on_tab1
 
作用:增加tab1表记录后自动将记录增加到tab2表中
 

drop trigger if exists `t_afterinsert_on_tab1`; 
create trigger t_afterinsert_on_tab1 
after insert on `tab1` 
for each row 
begin
   insert into tab2(tab2_id) values(new.tab1_id); 
end;

创建触发器:t_afterdelete_on_tab1
作用:删除tab1表记录后自动将tab2表中对应的记录删去

drop trigger if exists `t_afterdelete_on_tab1`; 
create trigger `t_afterdelete_on_tab1` 
after delete on `tab1` 
for each row 
begin
   delete from `tab2` where tab2_id=old.tab1_id; 
end;

删除触发器:
 

drop trigger [schema_name.]trigger_name;