当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL存储过程中的基本函数和触发器的相关学习教程

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

长春个人写真,百家乐合作,轴承型号查询

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;

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网