当前位置:七道奇文章资讯数据防范MySQL防范
日期:2012-06-02 15:06:00  来源:本站整理

MySql的存储历程学习小结 附pdf文档下载[MySQL防范]

赞助商链接



  本文“MySql的存储历程学习小结 附pdf文档下载[MySQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
存储历程是一种存储在数据库库中的程序(就像正规语言里的子程序一样),精确的来说,MySql支持的"routine(例程)"有两种:一是我们说的存储历程,二是在别的sql语句中可以返回值的函数(利用起来和mysql预装载的函数一样,如pi()).

一个存储历程包含名字,参数列表,以及可以包含很多sql语句的sql语句集.在这里对部分变量,非常处理,循环掌握和if条件语句有新的语法定义.

下面是一个包含存储历程的实例声明:
复制代码 代码以下:
CREATE PROCEDURE procedurel /*name 存储历程名*/
(IN parameter1 INTEGER) /*parameters 参数*/
BEGIN /*start of blokc 语句块头*/
DECLARE variable1 CHAR(10); /*variables变量声明*/
IF parameter1 = 17 THEN /*start of IF IF条件开始*/
SET variable1 = 'birds'; /*assignment赋值*/
END IF; /*end of IF IF完毕*/
INSERT INTO table1 VALUES (variable1);/*statement SQL语句*/
END /*end of block 语句块完毕*/


MySQL 版本:5.0.45 phpMyAdmin版本:2.11.3
首先看MySQL 5.0参考手册中关于成立存储历程的语法阐明:
CREATE
[DEFINER = { user | CURRENT_USER }]
PROCEDURE sp_name ([proc_parameter[,...]])
[characteristic ...] routine_body
proc_parameter:
[ IN | OUT | INOUT ] param_name type
type:
Any valid MySQL data type
characteristic:
LANGUAGE SQL
| [NOT] DETERMINISTIC
| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
| SQL SECURITY { DEFINER | INVOKER }
| COMMENT 'string'
routine_body:
Valid SQL procedure statement
假如你对MySQL还不太熟习的话,单单看这个语法构造当然不足以举行MySQL存储历程编程.我之前基本都是利用MS SQL SERVER,所以以下记录我熟习MySQL存储历程的历程,也是重点介绍MS SQL SERVER与MySQL辨别较大的地方.
第一步,当然是写个Hello Word的存储历程,以下:
复制代码 代码以下:
CREATE PROCEDURE phelloword()
BEGIN
SELECT 'Hello Word!' AS F;
END;

将上面成立phelloword存储历程的语句拷到phpMyAdmin中履行,报以下错误:
#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 '' at line 3
在这个问题上我胶葛了好久,在MySQL的号令行工具中履行一样不成功,但是按照提醒信息可以知道履行在 SELECT 'Hello Word!' AS F;处完毕,背面的END;没有履行,这明显会招致错误.
这里需求挑选以个脱离符,语法以下:DELIMITER //
脱离符是告诉MySQL客户端已经输入完成的标记.一向都是用";",但是在存储历程中不行,因为存储历程中很多语句都需求用到分号.
因此上面的存储历程改成:
复制代码 代码以下:
CREATE PROCEDURE ptest()
BEGIN
SELECT 'Hello Word!' AS F;
END //

别的在phpMyAdmin中履行时,在Delimiter文本框中填写 //,这次存储历程便可成立成功.
第二步,写一个包含参数,变量,变量赋值,条件判断,UPDATE语句,SELECT返回后果集的完好的一个存储历程,以下:
复制代码 代码以下:
CREATE PROCEDURE plogin
(
p_username char(15),
p_password char(32),
p_ip char(18),
p_logintime datetime
)
LABEL_PROC:
BEGIN
DECLARE v_uid mediumint(8);
DECLARE v_realpassword char(32);
DECLARE v_nickname varchar(30);
DECLARE v_oltime smallint(6);
SELECT u.uid, u.password, f.nickname, u.oltime INTO v_uid, v_realpassword, v_nickname, v_oltime
FROM cdb_members u INNER JOIN cdb_memberfields f ON f.uid = u.uid WHERE u.username = p_username;
IF (v_uid IS NULL) THEN
SELECT 2 AS ErrorCode;
LEAVE LABEL_PROC;
END IF;
IF (p_password <> v_realpassword) THEN
SELECT 3 AS ErrorCode;
LEAVE LABEL_PROC;
END IF;
UPDATE ipsp_userexpands SET lastloginip = p_ip, lastlogintime = p_logintime WHERE uid = v_uid;
SELECT 0 AS ErrorCode, v_uid AS uid, v_nickname AS nickname, v_oltime AS oltime;
END LABEL_PROC //

首先要说的是给变量赋值的语法,MySQL中利用SELECT u.uid, u.password, f.nickname, u.oltime INTO v_uid, v_realpassword, v_nickname, v_oltime FROM cdb_members u INNER JOIN cdb_memberfields f ON f.uid = u.uid WHERE u.username = p_username;这种方法给变量赋值.
其次是条件判断的语法构造,以下所示:
复制代码 代码以下:
IF ... THEN
...;
ELSE
IF ... THEN
...;
ELSEIF
...;
ELSE
...;
END IF;
END IF;

最后说说LEAVE 语法的利用.当满意某种条件,不持续履行下面的SQL时,在MS SQL SERVER中利用RETURN语法,在MySQL中我没有找到对应的关键字,但是这里可以操纵LEAVE语法来满意要求,在存储历程的BEGIN前定义一个标签,如:"LABEL_PROC:" 然后再需求用到RETURN中止履行的地方履行"LEAVE LABEL_PROC;"便可.
第三步,成立一个履行动态SQL的存储历程.
复制代码 代码以下:
CREATE PROCEDURE ipsp_getresourcedir
(
p_hashcode char(40)
)
LABEL_PROC:
BEGIN
DECLARE v_sql varchar(200);
SET v_sql = CONCAT('SELECT filedir FROM ipsp_resources WHERE hashcode =\'', p_hashcode, '\' LIMIT 0, 1');
SET @sql = v_sql;
PREPARE sl FROM @sql;
EXECUTE sl;
DEALLOCATE PREPARE sl;
END LABEL_PROC //

这里提一下 "\"是转义字符,拼接成的SQL近似 SELECT filedir FROM ipsp_resources WHERE hashcode ='xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' LIMIT 0, 1
别的@sql这个属于用户变量,具体用法请查询MySQL参考手册.
假若有在MS SQL SERVER上编写存储历程的经验的话,看完这些,我想基本的MySQL存储历程编程应当可以对付了吧!
想理解更多的内容可查询MySQL参考手册大概相关书籍!

mysql 5.0存储历程学习总结(更具体)

一.成立存储历程
1.基本语法:

create procedure sp_name()
begin
………
end
2.参数传送
二.调用存储历程
1.基本语法:call sp_name()
注意:存储历程名称背面必须加括号,哪怕该存储历程没有参数传送
三.删除存储历程
1.基本语法:
drop procedure sp_name//
2.注意事项
(1)不能在一个存储历程中删除另一个存储历程,只能调用另一个存储历程
四.区块,条件,循环

1.区块定义,常用
begin
……
end;
也可以给区块起别名,如:
lable:begin
………..
end lable;
可以用leave lable;跳出区块,履行区块今后的代码
2.条件语句

if 条件 then
statement
else
statement
end if;
3.循环语句
(1).while循环
[label:] WHILE expression DO
statements
END WHILE [label] ;

(2).loop循环

[label:] LOOP
statements
END LOOP [label];

(3).repeat until循环

[label:] REPEAT
statements
UNTIL expression
END REPEAT [label] ;

五.其他常用号令
1.show procedure status
显示数据库中全部存储的存储历程基本信息,包含所属数据库,存储历程名称,成立时间等
2.show create procedure sp_name
显示某一个存储历程的具体信息


mysql存储历程中要用到的运算符
mysql存储历程学习总结-操作符
算术运算符
+ 加 SET var1=2+2; 4
- 减 SET var2=3-2; 1
* 乘 SET var3=3*2; 6
/ 除 SET var4=10/3; 3.3333
DIV 整除 SET var5=10 DIV 3; 3
% 取模 SET var6=10%3 ; 1
对比运算符
> 大于 1>2 False
< 小于 2<1 False
<= 小于等于 2<=2 True
>= 大于等于 3>=2 True
BETWEEN 在两值之间 5 BETWEEN 1 AND 10 True
NOT BETWEEN 不在两值之间 5 NOT BETWEEN 1 AND 10 False
IN 在调集合 5 IN (1,2,3,4) False
NOT IN 不在调集合 5 NOT IN (1,2,3,4) True
= 等于 2=3 False
<>, != 不等于 2<>3 False
<=> 严峻对比两个NULL值能否相等 NULL<=>NULL True
LIKE 简单情势匹配 "Guy Harrison" LIKE "Guy%" True
REGEXP 正则式匹配 "Guy Harrison" REGEXP "[Gg]reg" False
IS NULL 为空 0 IS NULL False
IS NOT NULL 不为空 0 IS NOT NULL True
逻辑运算符
与(AND)

AND

TRUE

FALSE

NULL

TRUE

TRUE

FALSE

NULL

FALSE

FALSE

FALSE

NULL

NULL

NULL

NULL

NULL

或(OR)

OR

TRUE

FALSE

NULL

TRUE

TRUE

TRUE

TRUE

FALSE

TRUE

FALSE

NULL

NULL

TRUE

NULL

NULL

异或(XOR)

XOR

TRUE

FALSE

NULL

TRUE

FALSE

TRUE

NULL

FALSE

TRUE

FALSE

NULL

NULL

NULL

NULL

NULL

位运算符

| 位或
& 位与
<< 左移位
>> 右移位
~ 位非(单目运算,按位取反)

mysq存储历程中常用的函数,字符串范例操作,数学类,日期时间类.

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
  以上是“MySql的存储历程学习小结 附pdf文档下载[MySQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • Windows 搭配 IIS7 PHP MySQL 环境
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • mysql数据库插入速度和读取速度的调整记录
  • MySQL Order By索引优化办法
  • MySQL Order By用法分享
  • mysql #1062 –Duplicate entry ''1'' for key ''PRIMARY''
  • MySQL Order By Rand()效率解析
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .