MySQL存储过程实例

凉白开 MySQL1 13,510字数 982阅读3分16秒阅读模式

mysql在5.1之后增加了存储过程的功能, 存储过程运行在mysql内部,语句都已经编译好了,速度比sql更快. 存储过程与mysql相当于shelllinux系统。如果你是程序员的话,那我告诉你存储过程实际上是一个方法,你只要调用这个方法,并且输入它设置好的参数就可以获取或者执行你想要的操作了. 看了如下存储过程实例,你会发现mysql存储过程和shell很像.

下面存储过程内容为:调用存储过程,并且传入用户名,密码参数。存储过程会将这她们存储到process_test表里面.看实例文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

一,创建数据库文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

mysql>create database db_proc;

二,创建表文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

mysql>CREATE TABLE `proc_test` (
 `id` tinyint(4) NOT NULL AUTO_INCREMENT,  #ID,自动增长
 `username` varchar(20) NOT NULL, #用户名
 `password` varchar(20) NOT NULL, #密码
 PRIMARY KEY (`id`) #主键
 ) ENGINE=MyISAM AUTO_INCREMENT=50 DEFAULT CHARSET=utf8; #设置表引擎和字符集

三、创建存储过程文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

create procedure mytest(in name varchar(20),in pwd varchar(20))#定义传入的参数
 begin
 insert into proc_test(username,password) values(name,pwd);
#把传进来的参数name和pwd插入表中,别忘记分号
 end; #注意这个分号别忘记了

四、测试调用存储过程
用法:call 存储过程名称(传入的参数)文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

call proc_test("绝心是凉白开","www.ttlsa.com")

username为”绝心是凉白开“传入数据库中,密码”www.ttlsa.com“文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

五、查看数据库中有无加入的数据文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

select * from proc_test where username=‘绝心是凉白开’;#如果有内容说明成功了

六、删除存储过程
drop procdure 存储过程名;文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

本文是我几年前写的,太久没用存储过程,发现有点生疏,从新放开自己写的文章,马上想起它的用法,例子很简单,但是很实用。文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

转载请注明出处: https://www.ttlsa.com/html/3071.html文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/ 文章源自运维生存时间-https://www.ttlsa.com/mysql/mysql-procedures-example/

weinxin
我的微信
微信公众号
扫一扫关注运维生存时间公众号,获取最新技术文章~
凉白开
  • 本文由 发表于 19/09/2013 00:02:21
  • 转载请务必保留本文链接:https://www.ttlsa.com/mysql/mysql-procedures-example/
评论  1  访客  1
    • Glory_United
      Glory_United 0

      第四步 call 错了

    评论已关闭!