MySQL 存储过程的创建方案
以下的文章主要介绍的是MySQL 存储过程的实际操作解析,我们大家都知道一个MySQL 存储过程主要包括名字,参数列表,还有包括很多的SQL语句与SQL语句集。以下就是具体内容的描述, 创建MySQL 存储过程: 语法: CREATEPROCEDUREp() BEGIN /*此存储过程的正文*
以下的文章主要介绍的是MySQL 存储过程的实际操作解析,我们大家都知道一个MySQL 存储过程主要包括名字,参数列表,还有包括很多的SQL语句与SQL语句集。以下就是具体内容的描述,
创建MySQL 存储过程:
语法:
<ol class="dp-xml"> <li class="alt"><span><span>CREATE PROCEDURE p() </span></span></li> <li><span>BEGIN </span></li> </ol>
/*此存储过程的正文*/
<ol class="dp-xml"> <li class="alt"><span><span>END </span></span></li> <li><span>CREATE PROCEDURE productpricing() </span></li> <li class="alt"><span>BEGIN </span></li> <li><span>SELECT Avg(pro_price) AS priceaverage </span></li> <li class="alt"><span>FROM products; </span></li> <li><span>END; </span></li> <li class="alt"><span> </span></li> </ol>
begin…end之间是存储过程的主体定义
MySQL的分界符是分号(;)
调用存储过程的方法是:
CALL加上过程名以及一个括号
例如调用上面定义的MySQL 存储过程
<ol class="dp-xml"><li class="alt"><span><span>CALL productpricing(); </span></span></li></ol>
哪怕是不用传递参数,存储过程名字后面的括号“()”也是必须的
删除存储过程的方法是:
<ol class="dp-xml"><li class="alt"><span><span>DROP PROCUDURE productpricing; </span></span></li></ol>
创建带参数的存储过程:
<ol class="dp-xml"> <li class="alt"><span><span>CREATE PROCUDURE productpricing( </span></span></li> <li><span>OUT p1 DECIMAL(8,2), </span></li> <li class="alt"><span>OUT ph DECIMAL(8,2), </span></li> <li><span>OUT pa DECIMAL(8,2) </span></li> <li class="alt"><span>) </span></li> <li><span>BEGIN </span></li> <li class="alt"><span>SELECT Min(prod_price) INTO pl FROM products; </span></li> <li><span>SELECT Max(prod_price) INTO ph FROM products; </span></li> <li class="alt"><span>SELECT Avg(prod_price) INTO pa FROM products; </span></li> <li><span>END; </span></li> <li class="alt"><span> </span></li> </ol>
DECIMAL用于指定参数的数据类型
OUT用于表明此值是用于从存储过程里输出的
MySQL支持 OUT, IN, INOUT
调用带参数的MySQL 存储过程:
<ol class="dp-xml"> <li class="alt"><span><span>CALL productpricing(@pricelow, </span></span></li> <li><span>@pricehigh, </span></li> <li class="alt"><span>@priceaverage); </span></li> </ol>
所有的参数必须以@开头
要想获取@priceaverage的值,用以下语句
SELECT @priceaverage;
获取三个的值,用以下语句
<ol class="dp-xml"><li class="alt"><span><span>SELECT @pricehigh, @pricelow, @priceaverage; </span></span></li></ol>
另一个带IN和OUT参数的存储过程:
<ol class="dp-xml"> <li class="alt"><span><span>CREATE PROCEDURE ordertotal( </span></span></li> <li><span>IN onumber INT, </span></li> <li class="alt"><span>OUT ototal DECIMAL(8,2) </span></li> <li><span>) </span></li> <li class="alt"><span>BEGIN </span></li> <li><span>SELECT Sum(item_price*quantity) </span></li> <li class="alt"><span>FROM orderitems </span></li> <li> <span>WHERE </span><span class="attribute">order_num</span><span> = </span><span class="attribute-value">onumber</span><span> </span> </li> <li class="alt"><span>INTO ototal; </span></li> <li><span>END; </span></li> <li class="alt"><span>CALL ordertotal(20005, @total); </span></li> <li><span>SELECT @total; </span></li> </ol>
添加一个完整的例子:(这是一个自定义分页的MySQL 存储过程)
<ol class="dp-xml"> <li class="alt"><span><span>DELIMITER $$ </span></span></li> <li><span>DROP PROCEDURE IF EXISTS `dbcall`.`get_page`$$ </span></li> <li class="alt"> <span>CREATE </span><span class="attribute">DEFINER</span><span>=`root`@`localhost` PROCEDURE `get_page`( </span> </li> <li><span>/**//*Table name*/ </span></li> <li class="alt"><span>tableName varchar(100), </span></li> <li><span>/**//*Fileds to display*/ </span></li> <li class="alt"><span>fieldsNames varchar(100), </span></li> <li><span>/**//*Page index*/ </span></li> <li class="alt"><span>pageIndex int, </span></li> <li><span>/**//*Page Size*/ </span></li> <li class="alt"><span>pageSize int, </span></li> <li><span>/**//*Field to sort*/ </span></li> <li class="alt"><span>sortName varchar(500), </span></li> <li><span>/**//*Condition*/ </span></li> <li class="alt"><span>strWhere varchar(500) </span></li> <li><span>) </span></li> <li class="alt"><span>BEGIN </span></li> <li><span>DECLARE fieldlist varchar(200); </span></li> <li class="alt"> <span>if </span><span class="attribute">fieldsNames</span><span>=</span><span class="attribute-value">''</span><span>||</span><span class="attribute">fieldsNames</span><span>=</span><span class="attribute-value">null</span><span> THEN </span> </li> <li> <span>set </span><span class="attribute">fieldlist</span><span>=</span><span class="attribute-value">'*'</span><span>; </span> </li> <li class="alt"><span>else </span></li> <li> <span>set </span><span class="attribute">fieldlist</span><span>=</span><span class="attribute-value">fieldsNames</span><span>; </span> </li> <li class="alt"><span>end if; </span></li> <li> <span>if </span><span class="attribute">strWhere</span><span>=</span><span class="attribute-value">''</span><span>||</span><span class="attribute">strWhere</span><span>=</span><span class="attribute-value">null</span><span> then </span> </li> <li class="alt"> <span>if </span><span class="attribute">sortName</span><span>=</span><span class="attribute-value">''</span><span>||</span><span class="attribute">sortName</span><span>=</span><span class="attribute-value">null</span><span> then </span> </li> <li> <span>set @</span><span class="attribute">strSQL</span><span>=</span><span class="attribute-value">concat</span><span>('SELECT ',fieldlist,' FROM ',tableName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize); </span> </li> <li class="alt"><span>else </span></li> <li> <span>set @</span><span class="attribute">strSQL</span><span>=</span><span class="attribute-value">concat</span><span>('SELECT ',fieldlist,' FROM ',tableName,' ORDER BY ',sortName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize); </span> </li> <li class="alt"><span>end if; </span></li> <li><span>else </span></li> <li class="alt"> <span>if </span><span class="attribute">sortName</span><span>=</span><span class="attribute-value">''</span><span>||</span><span class="attribute">sortName</span><span>=</span><span class="attribute-value">null</span><span> then </span> </li> <li> <span>set @</span><span class="attribute">strSQL</span><span>=</span><span class="attribute-value">concat</span><span>('SELECT ',fieldlist,' FROM ',tableName,' WHERE ',strWhere,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize); </span> </li> <li class="alt"><span>else </span></li> <li> <span>set @</span><span class="attribute">strSQL</span><span>=</span><span class="attribute-value">concat</span><span>('SELECT ',fieldlist,' FROM ',tableName,' WHERE ',strWhere,' ORDER BY ',sortName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize); </span> </li> <li class="alt"><span>end if; </span></li> <li><span>end if; </span></li> <li class="alt"><span>PREPARE stmt1 FROM @strSQL; </span></li> <li><span>EXECUTE stmt1; </span></li> <li class="alt"><span>DEALLOCATE PREPARE stmt1; </span></li> <li><span>END$$ </span></li> <li class="alt"><span>DELIMITER ; </span></li> </ol>
以上的相关内容就是对MySQL 存储过程的介绍,望你能有所收获。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MySQL在Web應用中的主要作用是存儲和管理數據。 1.MySQL高效處理用戶信息、產品目錄和交易記錄等數據。 2.通過SQL查詢,開發者能從數據庫提取信息生成動態內容。 3.MySQL基於客戶端-服務器模型工作,確保查詢速度可接受。

在 Docker 中啟動 MySQL 的過程包含以下步驟:拉取 MySQL 鏡像創建並啟動容器,設置根用戶密碼並映射端口驗證連接創建數據庫和用戶授予對數據庫的所有權限

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

在開發一個小型應用時,我遇到了一個棘手的問題:需要快速集成一個輕量級的數據庫操作庫。嘗試了多個庫後,我發現它們要么功能過多,要么兼容性不佳。最終,我找到了minii/db,這是一個基於Yii2的簡化版本,完美地解決了我的問題。

優雅安裝 MySQL 的關鍵在於添加 MySQL 官方倉庫。具體步驟如下:下載 MySQL 官方 GPG 密鑰,防止釣魚攻擊。添加 MySQL 倉庫文件:rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm更新 yum 倉庫緩存:yum update安裝 MySQL:yum install mysql-server啟動 MySQL 服務:systemctl start mysqld設置開機自啟動

在 CentOS 上安裝 MySQL 涉及以下步驟:添加合適的 MySQL yum 源。執行 yum install mysql-server 命令以安裝 MySQL 服務器。使用 mysql_secure_installation 命令進行安全設置,例如設置 root 用戶密碼。根據需要自定義 MySQL 配置文件。調整 MySQL 參數和優化數據庫以提升性能。

文章摘要:本文提供了詳細分步說明,指導讀者如何輕鬆安裝 Laravel 框架。 Laravel 是一個功能強大的 PHP 框架,它 упростил 和加快了 web 應用程序的開發過程。本教程涵蓋了從系統要求到配置數據庫和設置路由等各個方面的安裝過程。通過遵循這些步驟,讀者可以快速高效地為他們的 Laravel 項目打下堅實的基礎。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。
