Home Database Mysql Tutorial mysql存储过程的应用

mysql存储过程的应用

Jun 07, 2016 pm 03:01 PM
linux mysql storage application Community process Enter

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 MySQL存储过程的创建 (1)。 格式 MySQL存储过程创建的格式:CREATE PROCEDURE 过程名 ([过程参数[,…]]) [特性 …] 过程体 这里先举个例子: mysql DELIMITER // mysql CREATE PROCEDURE proc1(

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入

  MySQL存储过程的创建

  (1)。 格式

  MySQL存储过程创建的格式:CREATE PROCEDURE 过程名 ([过程参数[,…]])

  [特性 …] 过程体

  这里先举个例子:

  mysql> DELIMITER //

  mysql> CREATE PROCEDURE proc1(OUT s int)

  -> BEGIN

  -> SELECT COUNT(*) INTO s FROM user;

  -> END

  -> //

  mysql> DELIMITER ;

  注:

  (1)这里需要注意的是DELIMITER //和DELIMITER ;两句,DELIMITER是分割符的意思,因为MySQL默认以";"为分隔符,如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要事先用DELIMITER关键字申明当前段分隔符,这样MySQL才会将";"当做存储过程中的代码,不会执行这些代码,用完了之后要把分隔符还原。

  (2)存储过程根据需要可能会有输入、输出、输入输出参数,这里有一个输出参数s,类型是int型,如果有多个参数用","分割开。

  (3)过程体的开始与结束使用BEGIN与END进行标识。

  这样,我们的一个MySQL存储过程就完成了,是不是很容易呢?看不懂也没关系,接下来,我们详细的讲解。

  下面的例子主要用到了

  Ⅰ。 if-then -else语句

  Ⅰ。 FOUND_ROWS() 语句

  #记录每天的步行、睡眠、体重、消耗卡路里等信息

  #userRecordDetail 表中,如果存在当天数据,则修改,否则新增

  #userRecord 表中,如果存在,则累加,否则新增

  #类型:1步行2睡眠3卡路里消耗4体重

  #CALL userRecord_create(1001,45,100,1000,1000,500,500,2,1);

  DROP PROCEDURE IF EXISTS pro_userRecord_stepNum;

  DELIMITER //

  CREATE PROCEDURE pro_userRecord_stepNum(IN p_userId INT,IN p_stepNum INT)

  BEGIN

  DECLARE RCount INT;

  -- 查看用户是否有详细记录

  SELECT id FROM userRecordDetail WHERE userId = p_userId AND DATE(createTime) = CURDATE() LIMIT 1;

  SELECT FOUND_ROWS() INTO RCount;

  IF (RCount=0) THEN

  --  查看userRecord是否有用户总记录信息,不存在,则添加,否则修改

  SELECT id  FROM userRecord WHERE userId = p_userId LIMIT 1;

  SELECT FOUND_ROWS() INTO RCount;

  IF(RCount = 0 )THEN

  INSERT  INTO `userRecord`(`userId`,`totalStep`,`updateTime`,`createTime`)

  VALUES (p_userId,p_stepNum,NOW(),NOW());

  ELSE

  UPDATE userRecord SET totalStep = totalStep+p_stepNum WHERE userId = p_userId;

  END IF;  -- 结束

  -- 插入一条用户记录详细信息

  INSERT  INTO `userRecordDetail`(`weigh`,`calorie`,`stepNum`,`userId`,

  `sleepTimes`,`lightSleepTimes`,`heavySleepTimes`,

  `wakeupNum`,`updateTime`,`createTime`)

  VALUES (0,0,p_stepNum, p_userId,0,0,0,0,NOW(),NOW());

  ELSE

  --  查看是否有用户总记录信息,不存在,则添加,否则修改

  SELECT id  FROM userRecord WHERE userId = p_userId LIMIT 1;

  SELECT FOUND_ROWS() INTO RCount;

  IF(RCount = 0 )THEN

  INSERT  INTO `userRecord`(`userId`,`totalStep`,`updateTime`,`createTime`)

  VALUES (p_userId,p_stepNum,NOW(),NOW());

  ELSE

  UPDATE userRecord SET totalStep = totalStep + p_stepNum WHERE userId = p_userId;

  END IF;

  -- 修改userRecordDetail

  UPDATE userRecordDetail SET stepNum = stepNum + p_stepNum WHERE userId = p_userId;

  END IF;

  END;//

[1] [2] [3] 

mysql存储过程的应用

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Linux Architecture: Unveiling the 5 Basic Components Linux Architecture: Unveiling the 5 Basic Components Apr 20, 2025 am 12:04 AM

The five basic components of the Linux system are: 1. Kernel, 2. System library, 3. System utilities, 4. Graphical user interface, 5. Applications. The kernel manages hardware resources, the system library provides precompiled functions, system utilities are used for system management, the GUI provides visual interaction, and applications use these components to implement functions.

Laravel Introduction Example Laravel Introduction Example Apr 18, 2025 pm 12:45 PM

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

Laravel framework installation method Laravel framework installation method Apr 18, 2025 pm 12:54 PM

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

MySQL and phpMyAdmin: Core Features and Functions MySQL and phpMyAdmin: Core Features and Functions Apr 22, 2025 am 12:12 AM

MySQL and phpMyAdmin are powerful database management tools. 1) MySQL is used to create databases and tables, and to execute DML and SQL queries. 2) phpMyAdmin provides an intuitive interface for database management, table structure management, data operations and user permission management.

MySQL vs. Other Programming Languages: A Comparison MySQL vs. Other Programming Languages: A Comparison Apr 19, 2025 am 12:22 AM

Compared with other programming languages, MySQL is mainly used to store and manage data, while other languages ​​such as Python, Java, and C are used for logical processing and application development. MySQL is known for its high performance, scalability and cross-platform support, suitable for data management needs, while other languages ​​have advantages in their respective fields such as data analytics, enterprise applications, and system programming.

laravel installation code laravel installation code Apr 18, 2025 pm 12:30 PM

To install Laravel, follow these steps in sequence: Install Composer (for macOS/Linux and Windows) Install Laravel Installer Create a new project Start Service Access Application (URL: http://127.0.0.1:8000) Set up the database connection (if required)

How to safely store JavaScript objects containing functions and regular expressions to a database and restore? How to safely store JavaScript objects containing functions and regular expressions to a database and restore? Apr 19, 2025 pm 11:09 PM

Safely handle functions and regular expressions in JSON In front-end development, JavaScript is often required...

Docker on Linux: Containerization for Linux Systems Docker on Linux: Containerization for Linux Systems Apr 22, 2025 am 12:03 AM

Docker is important on Linux because Linux is its native platform that provides rich tools and community support. 1. Install Docker: Use sudoapt-getupdate and sudoapt-getinstalldocker-cedocker-ce-clicotainerd.io. 2. Create and manage containers: Use dockerrun commands, such as dockerrun-d--namemynginx-p80:80nginx. 3. Write Dockerfile: Optimize the image size and use multi-stage construction. 4. Optimization and debugging: Use dockerlogs and dockerex

See all articles