mysql-存储过程

Jun 07, 2016 pm 04:27 PM
学ぶ ストレージ プロセス

mysql---存储过程 了解存储过程之前,先了解一下mysql的控制结构。 类C语言(if……else、while循环等)SQL也有自己的控制结构。 if……else控制结构: 例如: (1) span style=font-family:FangSong_GB2312;if 判断表达式 then 执行语句;end if;与c语言进

mysql---存储过程

了解存储过程之前,先了解一下mysql的控制结构。

类似C语言(if……else、while循环等)SQL也有自己的控制结构。


if……else控制结构:

例如:

(1)

<span style="font-family:FangSong_GB2312;">if 判断表达式 
   then 执行语句;
end if;

与c语言进行比较
if(判断表达式)
   执行语句;</span>
ログイン後にコピー

(2)

<span style="font-family:FangSong_GB2312;">if 判断表达式1 
   then 执行语句1;
else
   then  执行语句2;
end if;

与c语言进行比较
if(判断表达式1)
   执行语句1;
else 
   执行语句2;</span>
ログイン後にコピー

(3)

<span style="font-family:FangSong_GB2312;">if 判断表达式1 
   then 执行语句1;
elseif 判断表达式2 
   then  执行语句2;
……
elseif 判断表达式N 
   then 执行语句N;
else
   执行语句N+1;
end if;

与c语言进行比较
if(判断表达式1)
   执行语句1;
else if(判断表达式2)
   执行语句2;
……
else if(判断表达式N)
   执行语句N;
else
   执行语句N+1;</span>
ログイン後にコピー

需要注意所有的执行语句和end if都要以‘;’结束,而且判断表达式之后接then,还有一点与C语言不同的是elseif之间没有空格。

mysql中还有一些与if相关的函数

if(判断表达式,值1,值2) 如果表达式为“true”返回“值1”,表达式为“false”返回“值2”。类似于C语言中的三目运算符。

ifnull(表达式1,表达式2)如果表达式1不为空,则返回表达式1。如果表达式1为空,则返回表达式2

nullif(表达式1,表达式2)如果表达式1=表达式2,返回null ,否则返回表达式1。


case when控制结构:

有两种形式

(1)

<span style="font-family:FangSong_GB2312;">case 待判断值 
when 值1 then 输出1
when 值2 then 输出2
……
when 值N then 输出N
else 默认输出 end;  #如果输出时语句的话,最后的结尾要改成end case。输出的是值则是end

同C语言的switch相比较
switch(待判断值){
case 值1:输出1
          break;
case 值2:输出2
          break;
……
case 值N:输出N
          break;
default:默认输出
}</span>
ログイン後にコピー

(2)

<span style="font-family:FangSong_GB2312;">case
when 判断表达式1 then 输出1
when 判断表达式2 then 输出2
……
when 判断表达式N then 输出N
else 默认输出 end case; #如果输出时语句的话,最后的结尾要是end case。输出的是值则是end。</span>
ログイン後にコピー

while循环结构:

<span style="font-family:FangSong_GB2312;">while 判断表达式 do
循环体
end while;

C语言中的while循环
while(判断表达式){
循环体;
}</span>
ログイン後にコピー

loop循环结构:无条件循环

<span style="font-family:FangSong_GB2312;">标签:loop
循环体;
end loop;
可以通过"leave 标签"来跳出loop循环。</span>
ログイン後にコピー

repeat循环结构:

<span style="font-family:FangSong_GB2312;">repeat
循环体; 
until 判断表达式 end repeat;</span>
ログイン後にコピー


现在开始介绍存储过程,其实存储过程跟函数很像

查看当前存储过程的状态:show procedure status;

创建存储过程:

<span style="font-family:FangSong_GB2312;">create procedure 名称(参数列表)
begin
语句集
end;</span>
ログイン後にコピー

参数列表总是存在的,如果没有参数则应该是空参数列表(),参数必须指定数据类型而且每个参数默认都是一个in参数。要指定为其他参数,可以在参数前面加上out或inout关键字。默认的in类似于按值传递,在存储过程中对参数进行修改,调用者是看不到的。out参数只是用来从存储过程传回数据的,无论给参数传入什么值,这个参数的初始值始终是null。对于inout参数,调用者不仅可以设置参数的初始值,而且在过程中修改参数,调用者是看得到的类似与按地址传递

删除存储过程:drop procedure 名称;

查看存储过程:show create procedure 名称\G 类似于show create table 表名  \G的作用是横向显示

调用存储过程:call 名称(参数);

声明变量:

(1)declare变量名 变量类型 默认值;    声明变量必须在开头定义,如果没有默认值,初始值为null。作用范围是在begin……end内

(2)set @变量名=初始值;定义的变量是用户变量,在存储过程之外的sql也是可以调用的

变量赋值:set 变量名=变量值  切忌直接给变量赋值(变量名= 变量值)

还有一种给一个或多个变量赋值的方法:利用“select 指定列 into 指定变量”,所以select的结果必须是单行。

 

示例:

所有示例,都实现将分界符设置为'$'

delimiter $

1、测试if-else控制结构



2、测试case……when

第一种情况:

输出是值,结尾用end。一般用于select


输出是语句,结尾用end case。一般用于存储过程


第二种情况:

输出是语句,结尾用end case。一般用于存储过程


输出是值,结尾用end。一般用于select


3、测试while循环



4、测试loop



5、测试repeat



6、带参数的存储过程

默认为in的参数:按值传递

初始值为0的变量tmp作为参数传入存储过程后,虽然在存储过程内对其进行修改,但调用者再次查看tmp时,值仍然为0,没有变化


out参数:


由第一个select可以看出,out参数不允许将实参的值传入存储过程。通过第二个和第三个select可以看出,存储过程内部修改变量后可以返回给调用者。

与按地址传递还有所不同,out只允许返回值,不允许传入值。


inout参数:按地址传递,形参值改变会改变实参的值


第一个select结果为0,说明实参的值传进存储过程。第二个和第三个select结果表明,inout可以在存储过程内部修改形参的值,从而影响实参,类似于按地址传递

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ファーウェイは革新的なMEDストレージ製品を来年発売予定:ラック容量は10PBを超え、消費電力は2kW未満 ファーウェイは革新的なMEDストレージ製品を来年発売予定:ラック容量は10PBを超え、消費電力は2kW未満 Mar 07, 2024 pm 10:43 PM

このウェブサイトは3月7日、ファーウェイのデータストレージ製品ラインの社長である周岳峰博士が最近MWC2024カンファレンスに出席し、特にウォームデータ(WarmData)とコールドデータ(ColdData)用に設計された新世代のOceanStorArctic磁電ストレージソリューションをデモンストレーションしたと報じた。ファーウェイのデータストレージ製品ラインの社長である周岳峰氏は、一連の革新的なソリューションをリリースした 画像出典: このサイトに添付されているファーウェイの公式プレスリリースは次のとおりです: このソリューションのコストは磁気テープのコストより 20% 低く、そのコストは磁気テープのコストよりも 20% 低くなります。消費電力はハードディスクよりも90%低いです。外国のテクノロジーメディアのblocksandfilesによると、ファーウェイの広報担当者も磁気電子ストレージソリューションに関する情報を明らかにした:ファーウェイの磁気電子ディスク(MED)は磁気ストレージメディアの主要な革新である。初代ME

TRedis キャッシュ テクノロジーについて学ぶ TRedis キャッシュ テクノロジーについて学ぶ Jun 19, 2023 pm 08:01 PM

TRedis キャッシュ テクノロジは、Web サイトまたはアプリケーションのパフォーマンスと応答速度を向上させることができる高性能メモリ キャッシュ テクノロジです。この記事では、TRedis キャッシュ テクノロジの基本概念と、それをアプリケーションで使用する方法を紹介します。 TRedis キャッシュ テクノロジーとは何ですか? TRedis は、頻繁に使用されるデータをメモリに保存するメモリ キャッシュ テクノロジであり、これにより、このデータへのアクセス速度が向上します。この手法の主なアイデアは、インメモリ キャッシュを使用してデータベースまたはディスクの負荷を軽減することです。

Vue3+TS+Vite 開発スキル: データを暗号化して保存する方法 Vue3+TS+Vite 開発スキル: データを暗号化して保存する方法 Sep 10, 2023 pm 04:51 PM

Vue3+TS+Vite 開発のヒント: データを暗号化して保存する方法 インターネット技術の急速な発展に伴い、データ セキュリティとプライバシー保護がますます重要になっています。 Vue3+TS+Vite 開発環境では、データをどのように暗号化して保存するかが、すべての開発者が直面する必要がある問題です。この記事では、開発者がアプリケーションのセキュリティとユーザー エクスペリエンスを向上させるのに役立つ、一般的なデータ暗号化とストレージのテクニックをいくつか紹介します。 1. データ暗号化 フロントエンド データ暗号化 フロントエンド暗号化は、データ セキュリティを保護するための重要な部分です。よく使われる

ECache キャッシュ テクノロジについて学ぶ ECache キャッシュ テクノロジについて学ぶ Jun 20, 2023 am 08:10 AM

ECache は、コンピュータ アプリケーションの応答時間を短縮するためのシンプルかつ強力な方法を提供する Java キャッシュ フレームワークです。データをメモリに保存することで、アプリケーションがクライアントの要求に迅速に応答できるようになり、システムのスループットが向上します。この記事では、ECache キャッシュ技術の利点、インストールと使用方法などの基礎知識を紹介します。 1. ECache の利点 システム パフォーマンスの向上: ECache はキャッシュ データをメモリに保存します。つまり、アプリケーションは

Windows 11 でキャッシュをクリアする方法: 画像付きの詳細なチュートリアル Windows 11 でキャッシュをクリアする方法: 画像付きの詳細なチュートリアル Apr 24, 2023 pm 09:37 PM

キャッシュとは何ですか?キャッシュ (カシェイと発音) は、頻繁に要求されるデータや命令を保存するために使用される特殊な高速ハードウェアまたはソフトウェア コンポーネントであり、Web サイト、アプリケーション、サービス、およびシステムのその他の側面をより高速に読み込むために使用できます。 。キャッシュにより、最も頻繁にアクセスされるデータがすぐに利用できるようになります。キャッシュ ファイルはキャッシュ メモリとは異なります。キャッシュ ファイルとは、複数のプログラムで必要になる可能性がある、PNG、アイコン、ロゴ、シェーダーなどの頻繁に必要なファイルを指します。これらのファイルは物理ドライブ領域に保存され、通常は隠されています。一方、キャッシュ メモリは、メイン メモリや RAM よりも高速なメモリのタイプです。 CPUに近く、RAMに比べて高速なため、データアクセス時間が大幅に短縮されます。

概要: JSP ファイルを開く方法の簡単な概要 概要: JSP ファイルを開く方法の簡単な概要 Jan 31, 2024 pm 09:28 PM

JSP ファイルを開く方法 JSP (JavaServerPages) は、プログラマが HTML ページに Java コードを埋め込むことを可能にする動的 Web ページ テクノロジです。 JSP ファイルは、HTML コード、XML タグ、および Java コードを含むテキスト ファイルです。 JSP ファイルが要求されると、そのファイルは JavaServlet にコンパイルされ、Web サーバーによって実行されます。 JSP ファイルを開く方法 JSP ファイルを開く方法はいくつかあります。最も簡単な方法はテキストエディタを使用することです。

Redisson キャッシュ テクノロジーについて学ぶ Redisson キャッシュ テクノロジーについて学ぶ Jun 21, 2023 am 09:54 AM

Redisson は、Java アプリケーション用の Redis ベースのキャッシュ ソリューションです。 Java アプリケーションで Redis をキャッシュとして使用することをより便利かつ効率的にするための多くの便利な機能が提供されます。 Redisson が提供するキャッシュ機能には以下が含まれます。 1. 分散マッピング (マップ): Redisson は、分散マップを作成するための API をいくつか提供します。これらのマップには、キーと値のペア、ハッシュ エントリ、またはオブジェクトを含めることができ、複数のノード間での共有をサポートできます。

Ubuntu での Git インストール プロセス Ubuntu での Git インストール プロセス Mar 20, 2024 pm 04:51 PM

Git は、高速で信頼性が高く、適応性に優れた分散バージョン管理システムです。分散型の非線形ワークフローをサポートするように設計されており、あらゆる規模のソフトウェア開発チームに最適です。各 Git 作業ディレクトリは、すべての変更の完全な履歴を備えた独立したリポジトリであり、ネットワーク アクセスや中央サーバーがなくてもバージョンを追跡できます。 GitHub は、分散リビジョン管理のすべての機能を提供する、クラウド上でホストされる Git リポジトリです。 GitHub は、クラウド上でホストされる Git リポジトリです。 CLI ツールである Git とは異なり、GitHub には Web ベースのグラフィカル ユーザー インターフェイスがあります。これは、他の開発者との共同作業や、スクリプトへの変更の追跡などのバージョン管理に使用されます。

See all articles