Ubuntu22.04下 MySQL8创建并使用存储过程

在Ubuntu下的MySQL 8中创建并使用存储过程:

  1. 使用mysql命令登录到MySQL服务器,例如:
bash 复制代码
mysql -u root -p

输入root用户的密码。

  1. 选择你想要创建存储过程的数据库,例如:
sql 复制代码
CREATE DATABASE mydb;

USE mydb;

CREATE TABLE user (
  id INT AUTO_INCREMENT PRIMARY KEY,
  uid INT,
  name VARCHAR(100),
  email VARCHAR(255),
  pwd VARCHAR(100)
)CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;


CREATE TABLE user_id (
  id INT AUTO_INCREMENT PRIMARY KEY,
)CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;
  1. 复制存储过程代码,并粘贴到MySQL命令行界面中,然后按Enter键执行。例如:
sql 复制代码
delimiter //
CREATE DEFINER=`root`@`%` PROCEDURE `reg_user`(
    IN `new_name` VARCHAR(255), 
    IN `new_email` VARCHAR(255), 
    IN `new_pwd` VARCHAR(255), 
    OUT `result` INT)
BEGIN
    -- 如果在执行过程中遇到任何错误,则回滚事务
    DECLARE EXIT HANDLER FOR SQLEXCEPTION
    BEGIN
        -- 回滚事务
        ROLLBACK;
        -- 设置返回值为-1,表示错误
        SET result = -1;
    END;

    -- 开始事务
    START TRANSACTION;

    -- 检查用户名是否已存在
    IF EXISTS (SELECT 1 FROM `user` WHERE `name` = new_name) THEN
        SET result = 0; -- 用户名已存在
        COMMIT;
    ELSE
        -- 用户名不存在,检查email是否已存在
        IF EXISTS (SELECT 1 FROM `user` WHERE `email` = new_email) THEN
            SET result = 0; -- email已存在
            COMMIT;
        ELSE
            -- email也不存在,更新user_id表
            UPDATE `user_id` SET `id` = `id` + 1;

            -- 获取更新后的id
            SELECT `id` INTO @new_id FROM `user_id`;

            -- 在user表中插入新记录
            INSERT INTO `user` (`uid`, `name`, `email`, `pwd`) VALUES (@new_id, new_name, new_email, new_pwd);
            -- 设置result为新插入的uid
            SET result = @new_id; -- 插入成功,返回新的uid
            COMMIT;

        END IF;
    END IF;
    
END//
  1. 存储过程创建成功,会返回一个确认消息。

  2. 要调用存储过程并读取使用,你可以使用CALL语句,例如:

    sql 复制代码
    CALL reg_user('new_username', 'new_email@example.com', 'new_password', @result);

    这里@result是一个用户定义的变量,用于存储存储过程返回的结果。

  3. 调用存储过程后,你可以查询变量@result的值来获取结果:

    sql 复制代码
    SELECT @result;

请注意,确保你已经创建了useruser_id表,并且它们具有适当的字段和数据类型,以便存储过程可以正常工作。此外,确保user_id表有一个自增的id字段,以便在新用户注册时自动更新。

相关推荐
SHUIPING_YANG4 分钟前
根据用户id自动切换表查询
java·服务器·数据库
爱吃烤鸡翅的酸菜鱼17 分钟前
IDEA高效开发:Database Navigator插件安装与核心使用指南
java·开发语言·数据库·编辑器·intellij-idea·database
超奇电子21 分钟前
阿里云OSS预签名URL上传与临时凭证上传的技术对比分析
数据库·阿里云·云计算
chao_78924 分钟前
更灵活方便的初始化、清除方法——fixture【pytest】
服务器·自动化测试·python·pytest
神仙别闹34 分钟前
基于C#+SQL Server实现(Web)学生选课管理系统
前端·数据库·c#
枷锁—sha1 小时前
【DVWA系列】——CSRF——Medium详细教程
android·服务器·前端·web安全·网络安全·csrf
枷锁—sha1 小时前
跨站请求伪造漏洞(CSRF)详解
运维·服务器·前端·web安全·网络安全·csrf
scuter_yu1 小时前
腾讯云云服务器深度介绍
服务器·云计算·腾讯云
m0_653031361 小时前
PostgreSQL技术大讲堂 - 第97讲:PG数据库编码和区域(locale)答疑解惑
数据库·postgresql
群联云防护小杜1 小时前
深度隐匿源IP:高防+群联AI云防护防绕过实战
运维·服务器·前端·网络·人工智能·网络协议·tcp/ip