博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql存储过程
阅读量:7065 次
发布时间:2019-06-28

本文共 1141 字,大约阅读时间需要 3 分钟。

自学了一下mysql存储过程,采用的mysql版本是5.1.51-community server。

建立一个表

CREATE TABLE `fruit` (  `ID` int(10) NOT NULL,  `NAME` varchar(10) DEFAULT NULL,  `TYPENAME` varchar(10) DEFAULT NULL,  PRIMARY KEY (`ID`))

存储过程P_GET_TYPE_NAME是根据输入的类型号码判断水果类型。

DELIMITER $$DROP PROCEDURE IF EXISTS 'P_GET_TYPE_NAME' $$CREATE PROCEDURE P_GET_TYPE_NAME(IN ID int,OUT NAME VARCHAR(50) CHARACTER SET utf8)BEGIN	IF (ID = 1) THEN		SET NAME = '水果';	END IF;	IF (ID = 2) THEN		SET NAME = '蔬菜';	END IF;END $$DELIMITER ;;

存储过程P_INSERT_FRUIT是接受输入的水果信息,将信息插入水果表。

DELIMITER $$DROP PROCEDURE IF EXISTS 'P_INSERT_FRUIT' $$CREATE PROCEDURE P_INSERT_FRUIT(IN ID INT,IN NAME VARCHAR(10),IN TYPENO INT)BEGIN	SET @ID = ID;	SET @NAME = NAME;	SET @TYPENO = TYPENO;	SET @TYPENAME = NULL;	CALL P_GET_TYPE_NAME(@TYPENO,@TYPENAME);	SET @insertSql = CONCAT('INSERT INTO FRUIT VALUES(?,?,?)');	PREPARE stmtinsert FROM @insertSql;	EXECUTE stmtinsert USING @ID,@NAME,@TYPENAME;        DEALLOCATE PREPARE stmtinsert;END $$DELIMITER ;;

 关键字说明:

 DELIMITER关键字,用于声明什么符号做为存储过程结束的分界符,与";"区分开。

 SET声明了参数,@后跟参数名称。

 IN表示输入参数,OUT 表示输出参数。

 CALL调用其他存错过程(函数)。

转载于:https://www.cnblogs.com/damour-damocles/p/5010629.html

你可能感兴趣的文章
SFB 项目经验-22-如何查看存储的管理IP地址
查看>>
libevent入门教程:Echo Server based on libevent
查看>>
.NET/ASP.NETMVC 大型站点架构设计—迁移Model元数据设置项(自定义元数据提供程序)...
查看>>
一次服务器CPU占用率高的定位分析
查看>>
安装office2007 1706错误
查看>>
crontab中执行多条命令
查看>>
25 JavaScript的幻灯片用于在Web布局的精彩案例
查看>>
用C语言写的迅雷看看XV文件提取器及C语言源代码
查看>>
ccpuid:CPUID信息模块 V1.01版,支持GCC(兼容32位或64位的Windows/Linux)
查看>>
用dom4j操作XML文档(收集)
查看>>
WinForm实例源代码下载
查看>>
hdu 1829 A Bug's Life(并查集)
查看>>
每日英语:Chinese Writer Wins Literature Nobel
查看>>
java中三种主流数据库数据库(sqlserver,db2,oracle)的jdbc连接总结
查看>>
Oracle Apps AutoConfig
查看>>
[leetcode]Flatten Binary Tree to Linked List
查看>>
css颜色代码大全:(网页设计师和平面设计师常用)
查看>>
boost 1.52在windows下的配置
查看>>
素材锦囊——50个高质量的 PSD 素材免费下载《上篇》
查看>>
【转】oc中消息传递机制-附:对performSelector方法的扩充
查看>>