mySql存储过程及sql语法Word文件下载.docx
《mySql存储过程及sql语法Word文件下载.docx》由会员分享,可在线阅读,更多相关《mySql存储过程及sql语法Word文件下载.docx(9页珍藏版)》请在冰豆网上搜索。
True
大于等于
3>
BETWEEN
在两值之间
5BETWEEN1AND10
NOTBETWEEN
不在两值之间
5NOTBETWEEN1AND10
IN
在集合中
5IN(1,2,3,4)
NOTIN
不在集合中
5NOTIN(1,2,3,4)
等于
2=3
!
不等于
3
=>
严格比较两个NULL值是否相等
NULL<
NULL
LIKE
简单模式匹配
"
GuyHarrison"
LIKE"
Guy%"
REGEXP
正则式匹配
REGEXP"
[Gg]reg"
ISNULL
为空
0ISNULL
ISNOTNULL
不为空
0ISNOTNULL
逻辑运算符
与(AND)
AND
TRUE
FALSE
NULL
或(OR)
OR
异或(XOR)
XOR
位运算符
|
位或
&
位与
左移位
右移位
~
位非(单目运算,按位取反)
mysql5.0存储过程学习总结
一.创建存储过程
1.基本语法:
createproceduresp_name()
begin
.........
end
2.参数传递
二.调用存储过程
callsp_name()
注意:
存储过程名称后面必须加括号,哪怕该存储过程没有参数传递
三.删除存储过程
dropproceduresp_name//
2.注意事项
(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程
四.区块,条件,循环
1.区块定义,常用
......
end;
也可以给区块起别名,如:
lable:
...........
endlable;
可以用leavelable;
跳出区块,执行区块以后的代码
2.条件语句
if
条件
then
statement
else
end
if;
3.循环语句
(1).while循环
[label:
]
WHILE
expression
DO
statements
END
[label]
;
(2).loop循环
LOOP
LOOP
[label];
(3).repeatuntil循环
REPEAT
UNTIL
expression
REPEAT
五.其他常用命令
1.showprocedurestatus
显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等
2.showcreateproceduresp_name
显示某一个存储过程的详细信息
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>
selectsubstring('
abcd'
0,2);
+-----------------------+
|substring('
0,2)|
|
1rowinset(0.00sec)
select'
1,2);
1,2)|
|ab
1rowinset(0.02sec)
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)默认变为整形值
selectround(1.23);
+-------------+
|round(1.23)|
1|
selectround(1.56);
|round(1.56)|
2|
(2)可以设定小数位数,返回浮点型数据
selectround(1.567,2);
+----------------+
|round(1.567,2)|
1.57|
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,INTERVALd_valued_type)//在date2中加上日期或时间
DATE_FORMAT(datetime,FormatCodes)//使用formatcodes格式显示datetime
DATE_SUB(date2,INTERVALd_valued_type)//在date2上减去一个时间
DATEDIFF(date1,date2)//两个日期差
DAY(date)//返回日期的天
DAYNAME(date)//英文星期
DAYOFWEEK(date)//星期(1-7),1为星期天
DAYOFYEAR(date)//一年中的第几天
EXTRACT(interval_name
FROMdate)//从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出错代码列表
mysql出错了,以前往往靠猜.现在有了这张表,一查就出来了.
1005:
创建表失败
1006:
创建数据库失败
1007:
数据库已存在,创建数据库失败
1008:
数据库不存在,删除数据库失败
1009:
不能删除数据库文件导致删除数据库失败
1010:
不能删除数据目录导致删除数据库失败
1011:
删除数据库文件失败
1012:
不能读取系统表中的记录
1020:
记录已被其他用户修改
1021:
硬盘剩余空间不足,请加大硬盘可用空间
1022:
关键字重复,更改记录失败
1023:
关闭时发生错误
1024:
读文件错误
1025:
更改名字时发生错误
1026:
写文件错误
1032:
记录不存在
1036:
数据表是只读的,不能对它进行修改
1037:
系统内存不足,请重启数据库或重启服务器
1038:
用于排序的内存不足,请增大排序缓冲区
1040:
已到达数据库的最大连接数,请加大数据库可用连接数
1041:
系统内存不足
1042:
无效的主机名
1043:
无效连接
1044:
当前用户没有访问数据库的权限
1045:
不能连接数据库,用户名或密码错误
1048:
字段不能为空
1049:
数据库不存在
1050:
数据表已存在
1051:
数据表不存在
1054:
字段不存在(SQLSTATE:
42S22)
1065:
无效的SQL语句,SQL语句为空
1081:
不能建立Socket连接
1114:
数据表已满,不能容纳任何记录
1116:
打开的数据表太多
1129:
数据库出现异常,请重启数据库
1130:
连接数据库失败,没有连接数据库的权限
1133:
数据库用户不存在
1141:
当前用户无权访问数据库
1142:
当前用户无权访问数据表
1143:
当前用户无权访问数据表中的字段
1146:
1147:
未定义用户对数据表的访问权限
1149:
SQL语句语法错误
1158:
网络错误,出现读错误,请检查网络连接状况
1159:
网络错误,读超时,请检查网络连接状况
1160:
网络错误,出现写错误,请检查网络连接状况
1161:
网络错误,写超时,请检查网络连接状况
1062:
字段值重复,入库失败
1064:
语法错误,常见的比如注释--后没加空格
1169:
字段值重复,更新记录失败
1177:
打开数据表失败
1180:
提交事务失败
1181:
回滚事务失败
1193:
变量没声明,常在写存储过程时发生
1203:
当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库
1205:
加锁超时
1211:
当前用户没有创建用户的权限
1216:
外键约束检查失败,更新子表记录失败
1217:
外键约束检查失败,删除或修改主表记录失败
1226:
当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器
1227:
权限不足,您无权进行此操作
1235:
MySQL版本过低,不具有本功能
更详细的错误信息可以访问