当前位置:   article > 正文

MySQL存储过程——if判断示例_floor(rand() * 999999999), 9, '0

floor(rand() * 999999999), 9, '0

通过Baidu Comate智能代码助手学习if判断的使用

问题:

通过选中的DDL帮我生成一条添加语句的存储过程,要求传入的3个参数分别为userName,age,introduce,其它数据随机,输入的数据不允许为空,且userName的名称不允许以张王李兆开头。

结果:

  1. DELIMITER //
  2. CREATE PROCEDURE InsertStudent(
  3. IN p_userName VARCHAR(255),
  4. IN p_age INT,
  5. IN p_introduce TEXT
  6. )
  7. BEGIN
  8. -- 检查输入参数不为空
  9. IF p_userName IS NULL OR p_age IS NULL OR p_introduce IS NULL THEN
  10. SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Input parameters cannot be NULL';
  11. END IF;
  12. -- 检查userName不以张、王、李、兆开头
  13. IF LEFT(p_userName, 1) = '张' OR LEFT(p_userName, 1) = '王'
  14. OR LEFT(p_userName, 1) = '李' OR LEFT(p_userName, 1) = '兆' THEN
  15. SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'userName cannot start with 张, 王, 李, or 兆';
  16. END IF;
  17. -- 插入语句,其中createDate和phone为随机数据,sex为随机枚举值
  18. INSERT INTO student (createDate, userName, phone, age, sex, introduce)
  19. VALUES (
  20. -- createDate: 随机日期(例如:过去10年内)
  21. DATE_ADD(NOW(), INTERVAL FLOOR(RAND() * (0 - 3650) + 0) DAY),
  22. -- userName: 使用传入的参数
  23. p_userName,
  24. -- phone: 随机电话号码(例如:以138开头的11位数字)
  25. CONCAT('138', LPAD(FLOOR(RAND() * 999999999), 9, '0')),
  26. -- age: 使用传入的参数
  27. p_age,
  28. -- sex: 随机性别(M, F, 或 O)
  29. ELT(1 + FLOOR(RAND() * 3), 'M', 'F', 'O'),
  30. -- introduce: 使用传入的参数
  31. p_introduce
  32. );
  33. END //
  34. DELIMITER ;

在上面的存储过程中,我们首先通过SIGNAL SQLSTATE语句来检查传入的参数是否为空或者userName是否以特定的字开头。如果检查不通过,则存储过程会抛出一个错误。如果检查通过,则会执行INSERT INTO语句来添加一条新的记录到student表中。

请注意,为了简化电话号码的生成逻辑,我在示例中使用了一个以138开头的随机9位数字。根据你的实际需求,你可能需要调整这部分逻辑以生成符合你所在地区电话号码规则的随机号码。

要调用这个存储过程并添加一条记录,你可以使用以下SQL语句:

CALL InsertStudent('SampleName', 25, 'This is a sample introduction.');

测试后,如果是对应的结果:

说明存储过程正确,判断结果无异常。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/木道寻08/article/detail/1020176
推荐阅读
相关标签
  

闽ICP备14008679号