Heim Datenbank MySQL-Tutorial MySQL存储过程编程教程读书笔记-第二章MySQL存储过程编程指南-存_MySQL

MySQL存储过程编程教程读书笔记-第二章MySQL存储过程编程指南-存_MySQL

Jun 01, 2016 pm 01:26 PM
编程教程 编程语言 Notizen lesen

bitsCN.com

MySQL存储过程编程时一个复杂的主题,我们将在本章中为你提供完成基本任务的内容,其中包括:

1、怎样创建存储过程

2、存储过程怎样进行输入输出

3、怎样和数据库交互

4、怎样用MySQL存储编程语言创建过程,函数和触发器

第一个存储过程实例:

delimiter $$drop procedure if exists HelloWorld$$create procedure HelloWorld()begin     select "Hello World";end $$变量 
Nach dem Login kopieren

本地变量可以用declare语句进行声明。变量名称必须遵循MySQL的列明规则,并且可以使MySQL内建的任何数据类型。你可以用default字句给变量一个初始值,并且可以用SET语句给变量赋一个新值

delimiter $$drop procedure if exists variable_demo$$begin     declare my_integer int;    declare my_big_integer bigint;    declare my_currency numeric(8, 2);    declare my_pi float        default 3.1415926;    declare my_text text;    declare my_dob date        default '1960-06-21';    declare my_varchar varchar(30)        default "Hello World!";    set my_integer = 20;    set my_big_integer = power(my_integer, 3);end $$delimiter;
Nach dem Login kopieren

参数

参数可以使我们的存储程序更为灵活,更为实用。参数包括IN(只读模式), INOUT(可读写模式)和OUT(只写模式)。IN模式作为缺省的参数模式。

IN:任何对于该参数的修改都不会返回给调用它的程序

OUT:这个模式意味着存储过程可以对参数赋值(修改参数的值),并且这个被修改的值会被返回给它的调用程序

INOUT:这个模式意味着存储过程即可读取传入的参数,而且任何对于该参数的修改对于它的调用程序而言都是可见的

对于存储函数而言,只能使用IN模式

delimiter $$drop procedure if exists my_sqrt$$create procedure my_sqrt(input_number int, out out_number float)begin    set out_number = SQRT(input_number);end $$delimiter;
Nach dem Login kopieren
创建和执行使用OUT参数的存储过程
call my_sqrt(12, @out_value) $$select @out_value $$条件执行
Nach dem Login kopieren

通过购买量的多少来计算出贴现率的存储程序,购买量超过$500可以返回20%,购买量超过$100可以返回10%。

delimiter $$drop procedure if exists discounted_price$$create procedure discounted_price(normal_price NUMERIC(8, 2), out discount_price NUMBERIC(8, 2))begin     if (normal_price > 500) then         set discount_price = normal_price*.8;    else if (normal_price > 100) then         set discount_price = normal_price*.9;    else         set discount_price = normal_price;    end if;end$$delimiter;循环
Nach dem Login kopieren

MySQL存储程序语言提供了三种类型的循环

使用LOOP和END LOOP字句的简单循环

当循环条件为真时继续执行的循环,使用WHILE和END WHILE字句

循环直至条件为真,使用REPEAT和UNTIL字句

在这三种循环中,你都可以使用LEAVE字句来终止循环

DELIMITER $$DROP PROCEDURE IF EXISTS simple_loop$$CREATE PROCEDURE simple_loop()BEGIN    DECLARE counter INT DEFAULT 0;    my_simple_loop: LOOP        SET counter = counter 1;        IF counter = 10 THEN           LEAVE my_simple_loop;        END IF;    END IF;END LOOP my_simple_loop;select "I can count to 10";END$$ DELIMITER;错误处理
Nach dem Login kopieren

1、如果你认为内嵌的SQL语句会返回空记录,或者你想用游标捕获SELECT语句所返回的记录,那么一个NO FOUND 错误处理可以防止存储过程过早的被终止

2、如果你认为SQL语句可能返回错误(比如违背约束条件),你可以创建一个错误处理来阻止程序终止。这个处理将代替你的默认错误处理并继续程序的执行。

和数据库交互

大多数存储过程包含了各种和数据库表的交互,它们包括四种主要的交互:

1、将一个SQL语句所返回的单个记录放入本地变量中。

2、创建一个“游标”来迭代SQL语句所返回的结果集

3、执行一个SQL语句,将执行后的结果集返回给它的调用程序

4、内嵌一个不反悔结果集的SQL语句,如INSERT,UPDATE, DELETE等

对本地变量使用SELECT INTO

当需要在单个记录数据中获取查询信息,你就可以使用SELECT INTO 语法(无论是使用单个记录,多个记录的混合数据,还是多个表连接)。在这种情况下,你可以再SELECT语句中跟随一个INTO子句,告诉MySQL得到的查询数据返回给谁

DELIMITER $$ DROP PROCEDURE IF EXISTS customer_sales $$ CREATE PROCEDURE customer_sales(int_customer_id INT) READS SQL DATA BEGIN DECLARE total_sales NUMERIC(8, 2); SELECT SUM(sale_value) INTO total_sales FROM sales WHERE customer_id = in_customer_id; SELECT CONCAT('Total sales for ', in_customer_id, 'is', 'total_sales'); END; $$
Nach dem Login kopieren

使用游标

SELECT INTO 定义了单记录查询,但是很多应用程序要求查询多记录数据,你可以使用MySQL中的游标来实现这一切,游标允许你将一个或更多的SQL结果集放进存储程序变量中,通常用来执行结果集中各个单记录的处理。

DELIMITER $$ DROP PROCEDURE cursor_example() READ SQL DATA BEGIN DECLARE l_employee_id INT; DECLARE l_salary NUMERIC(8, 2); DECLARE l_department_id INT; DECLARE done INT DEFAULT 0; DECLARE curl CURSOR FOR SELECT employee_id, salary, department_id FROM employees; DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; OPEN curl; emp_loop : LOOP FETCH curl INTO l_employee_id, l_salary, l_department_id; IF done = 1 THEN LEAVE emp_loop; END IF; END LOOP emp_loop;
Nach dem Login kopieren
CLOSE curl;
END;$$ bitsCN.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Zwei -Punkte -Museum: Alle Exponate und wo man sie finden kann
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Das offizielle Einführungs-Tutorial von Huawei für die Programmiersprache Cangjie wird veröffentlicht. Erfahren Sie in einem Artikel, wie Sie die universelle Version des SDK erhalten Das offizielle Einführungs-Tutorial von Huawei für die Programmiersprache Cangjie wird veröffentlicht. Erfahren Sie in einem Artikel, wie Sie die universelle Version des SDK erhalten Jun 25, 2024 am 08:05 AM

Laut Nachrichten dieser Website vom 24. Juni kündigte Gong Ti, Präsident der Softwareabteilung von Huawei Terminal BG, bei der Grundsatzrede der Huawei-Entwicklerkonferenz HDC2024 am 21. Juni offiziell die von Huawei selbst entwickelte Programmiersprache Cangjie an. Diese Sprache wurde fünf Jahre lang entwickelt und steht jetzt als Entwicklervorschau zur Verfügung. Auf der offiziellen Entwickler-Website von Huawei wurde jetzt das offizielle Einführungsvideo zur Programmiersprache Cangjie veröffentlicht, um Entwicklern den Einstieg und das Verständnis zu erleichtern. Dieses Tutorial führt Benutzer dazu, Cangjie zu erleben, Cangjie zu lernen und Cangjie anzuwenden, einschließlich der Verwendung der Cangjie-Sprache zur Schätzung von Pi, der Berechnung der Stamm- und Zweigregeln für jeden Monat des Jahres 2024, der N Möglichkeiten, Binärbäume in der Cangjie-Sprache auszudrücken, und der Verwendung der Aufzählung Typen zur Implementierung algebraischer Berechnungen, Signalsystemsimulation mithilfe von Schnittstellen und Erweiterungen sowie neuer Syntax mithilfe von Cangjie-Makros usw. Diese Site hat die Tutorial-Zugriffsadresse: ht

Nach fünf Jahren Forschung und Entwicklung hat Huaweis Programmiersprache der nächsten Generation „Cangjie' offiziell seine Vorschau veröffentlicht Nach fünf Jahren Forschung und Entwicklung hat Huaweis Programmiersprache der nächsten Generation „Cangjie' offiziell seine Vorschau veröffentlicht Jun 22, 2024 am 09:54 AM

Diese Website berichtete am 21. Juni, dass Gong Ti, Präsident der Softwareabteilung von Huawei Terminal BG, heute Nachmittag auf der Huawei-Entwicklerkonferenz HDC2024 offiziell die von Huawei selbst entwickelte Cangjie-Programmiersprache angekündigt und eine Entwicklervorschauversion der Cangjie-Sprache HarmonyOSNEXT veröffentlicht hat. Dies ist das erste Mal, dass Huawei die Programmiersprache Cangjie öffentlich veröffentlicht. Gong Ti sagte: „Im Jahr 2019 wurde das Cangjie-Programmiersprachenprojekt bei Huawei geboren. Nach fünf Jahren voller Forschung und Entwicklung und hohen Investitionen in Forschung und Entwicklung trifft es heute endlich auf globale Entwickler. Die Cangjie-Programmiersprache integriert moderne Sprachfunktionen, umfassende Kompilierungsoptimierung und Laufzeitimplementierung.“ und die sofort einsatzbereite IDE-Toolkettenunterstützung sorgen für ein benutzerfreundliches Entwicklungserlebnis und eine hervorragende Programmleistung für Entwickler. „Berichten zufolge ist die Programmiersprache Cangjie ein All-Szenario-Intelligence-Tool.

Huawei startet Beta-Rekrutierung für Entwickler der Programmiersprache HarmonyOS NEXT Cangjie Huawei startet Beta-Rekrutierung für Entwickler der Programmiersprache HarmonyOS NEXT Cangjie Jun 22, 2024 am 04:07 AM

Laut Nachrichten dieser Website vom 21. Juni wurde die von Huawei selbst entwickelte Cangjie-Programmiersprache heute offiziell vorgestellt, und der Beamte kündigte den Start der Beta-Rekrutierung für die Vorschauversion der Cangjie-Sprachentwickler von HarmonyOSNEXT an. Bei diesem Upgrade handelt es sich um ein Early-Adopter-Upgrade auf die Entwicklervorschauversion, das das Cangjie-Sprach-SDK, Entwicklerhandbücher und zugehörige DevEcoStudio-Plug-Ins bereitstellt, damit Entwickler die Cangjie-Sprache zum Entwickeln, Debuggen und Ausführen von HarmonyOSNext-Anwendungen verwenden können. Anmeldezeitraum: 21. Juni 2024 – 21. Oktober 2024 Bewerbungsvoraussetzungen: Diese Rekrutierungsveranstaltung für HarmonyOSNEXT Cangjie Language Developer Preview Beta steht nur den folgenden Entwicklern offen: 1) Echte Namen wurden in der Huawei Developer Alliance-Zertifizierung vervollständigt 2) Vervollständigen Sie H

Die Tianjin-Universität und die Beihang-Universität sind maßgeblich am „Cangjie'-Projekt von Huawei beteiligt und haben das erste KI-Agent-Programmier-Framework „Cangqiong' auf Basis inländischer Programmiersprachen auf den Markt gebracht. Die Tianjin-Universität und die Beihang-Universität sind maßgeblich am „Cangjie'-Projekt von Huawei beteiligt und haben das erste KI-Agent-Programmier-Framework „Cangqiong' auf Basis inländischer Programmiersprachen auf den Markt gebracht. Jun 23, 2024 am 08:37 AM

Laut Nachrichten dieser Website vom 22. Juni stellte Huawei gestern Entwicklern auf der ganzen Welt die von Huawei selbst entwickelte Programmiersprache Cangjie vor. Dies ist der erste öffentliche Auftritt der Programmiersprache Cangjie. Laut Anfragen auf dieser Website waren die Tianjin-Universität und die Pekinger Universität für Luft- und Raumfahrt stark an der Forschung und Entwicklung von Huaweis „Cangjie“ beteiligt. Tianjin-Universität: Cangjie-Programmiersprachen-Compiler Das Software-Engineering-Team der Abteilung für Intelligenz und Informatik der Tianjin-Universität hat sich mit dem Huawei Cangjie-Team zusammengetan, um sich intensiv an der Qualitätssicherungsforschung des Cangjie-Programmiersprachen-Compilers zu beteiligen. Berichten zufolge ist der Cangjie-Compiler die Basissoftware, die eine Symbiose mit der Programmiersprache Cangjie eingeht. In der Vorbereitungsphase der Cangjie-Programmiersprache wurde ein hochwertiger Compiler, der dazu passt, zu einem der Kernziele. Während sich die Programmiersprache Cangjie weiterentwickelt, wird der Cangjie-Compiler ständig aktualisiert und verbessert. In den letzten fünf Jahren an der Tianjin-Universität

Was soll ich tun, wenn der Microsoft Edge-Browser keine Bilder anzeigt? – Was tun, wenn der Microsoft Edge-Browser keine Bilder anzeigt? Was soll ich tun, wenn der Microsoft Edge-Browser keine Bilder anzeigt? – Was tun, wenn der Microsoft Edge-Browser keine Bilder anzeigt? Mar 04, 2024 pm 07:43 PM

Kürzlich haben viele Freunde den Editor gefragt, was zu tun ist, wenn der Microsoft Edge-Browser keine Bilder anzeigt. Als Nächstes erfahren Sie, wie Sie das Problem lösen können, dass der Microsoft Edge-Browser keine Bilder anzeigt. 1. Klicken Sie zum Starten zunächst auf die untere linke Ecke und dann mit der rechten Maustaste auf „Microsoft Edge Browser“, wie in der folgenden Abbildung dargestellt. 2. Wählen Sie dann „Mehr“ und klicken Sie auf „App-Einstellungen“, wie in der Abbildung unten gezeigt. 3. Scrollen Sie dann nach unten, um „Bilder“ zu finden, wie im Bild unten gezeigt. 4. Schalten Sie abschließend den Schalter unter dem Bild ein, wie im Bild unten gezeigt. Das Obige ist der gesamte Inhalt, den Ihnen der Editor zur Verfügung stellt, was zu tun ist, wenn der Microsoft Edge-Browser keine Bilder anzeigt. Ich hoffe, dass er Ihnen hilfreich sein kann.

Huaweis selbst entwickelte offizielle Website und Entwicklungsdokumente für die Programmiersprache Cangjie sind online und integrieren sich erstmals in das Hongmeng-Ökosystem Huaweis selbst entwickelte offizielle Website und Entwicklungsdokumente für die Programmiersprache Cangjie sind online und integrieren sich erstmals in das Hongmeng-Ökosystem Jun 22, 2024 am 03:10 AM

Laut Nachrichten dieser Website wurde am 21. Juni vor der Huawei-Entwicklerkonferenz HDC2024 die von Huawei selbst entwickelte Programmiersprache Cangjie offiziell vorgestellt und die offizielle Website von Cangjie ist jetzt online. Die offizielle Einführung auf der Website zeigt, dass die Programmiersprache Cangjie eine Programmiersprache der neuen Generation für All-Szenario-Intelligenz ist, die sich auf „native Intelligenz, natürliche All-Szenarien, hohe Leistung und starke Sicherheit“ konzentriert. Integrieren Sie sich in das Hongmeng-Ökosystem, um Entwicklern ein gutes Programmiererlebnis zu bieten. Die dieser Website beigefügte offizielle Website stellt Folgendes vor: Natives intelligentes Programmier-Framework, eingebettet in AgentDSL, organische Integration natürlicher Sprache und Multi-Agent-Zusammenarbeit, vereinfachter symbolischer Ausdruck, freie Kombination von Mustern, Unterstützung der Entwicklung verschiedener intelligenter Anwendungen; Von Natur aus leichte und skalierbare Laufzeit für alle Szenen, modulares Schichtdesign, egal wie klein der Speicher ist, es kann eine Domänenerweiterung für alle Szenarien berücksichtigt werden

Vergleich der Vor- und Nachteile der C++-Technologie und anderer moderner Programmiersprachen Vergleich der Vor- und Nachteile der C++-Technologie und anderer moderner Programmiersprachen Jun 01, 2024 pm 10:15 PM

Ein Vergleich der Vor- und Nachteile von C++ mit anderen modernen Programmiersprachen lautet: Vorteile von C++: hohe Leistung, Steuerung auf niedriger Ebene, reichhaltiges Bibliotheksökosystem. Nachteile von C++: Steile Lernkurve, manuelle Speicherverwaltung, eingeschränkte Portabilität. Vorteile von Python: reibungslose Lernkurve, umfangreiche Bibliotheksunterstützung, interpretierte Sprache. Vorteile von Java: Plattformunabhängig, automatische Speicherverwaltung, breite Anwendung. Vorteile von JavaScript: wesentlich für die Front-End-Entwicklung, leichtgewichtiger, dynamischer Typ.

So löschen Sie den Verlauf in Microsoft Teams – So löschen Sie den Verlauf So löschen Sie den Verlauf in Microsoft Teams – So löschen Sie den Verlauf Mar 18, 2024 pm 08:40 PM

Kürzlich haben einige Freunde den Herausgeber befragt, wie man den Verlauf von Microsoft Teams löscht. Im Folgenden erfahren Sie, wie Sie den Verlauf von Microsoft Teams löschen können. Schritt 1: Wählen Sie zunächst in der Einstellungsoberfläche Daten- und Speicheroptionen aus. Schritt 2: Wählen Sie auf der Popup-Seite die Option „Verlauf löschen“. Schritt 3: Wählen Sie auf der Popup-Seite die letzte Option aus.

See all articles