MySQL存储过程中的基本函数和触发器的相关学习教程
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;
上一篇: Linux 批量kill死进程
下一篇: Linux批量kill进程
推荐阅读
-
MySQL存储过程中的基本函数和触发器的相关学习教程
-
MySQL存储过程中一些基本的异常处理教程
-
[MySQL] 存储过程、函数、触发器和视图的权限检查_MySQL
-
MySql存储过程中的基本函数和需要用到的运算符
-
C语言线性单链表相关函数和算法的基本实现详细教程
-
Mysql-自带的一些功能,基本用法(视图,触发器,事务,存储过程,函数,流程控制)
-
MySQL索引、触发器、常用函数、存储过程和函数、数据备份与还原的介绍
-
MySQL的使用学习之存储过程和函数
-
基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程),开题-mysql_PHP教程
-
[MySQL] 存储过程、函数、触发器和视图的权限检查_MySQL