赞
踩
通过Baidu Comate智能代码助手学习if判断的使用
问题:
通过选中的DDL帮我生成一条添加语句的存储过程,要求传入的3个参数分别为userName,age,introduce,其它数据随机,输入的数据不允许为空,且userName的名称不允许以张王李兆开头。
- DELIMITER //
- CREATE PROCEDURE InsertStudent(
- IN p_userName VARCHAR(255),
- IN p_age INT,
- IN p_introduce TEXT
- )
- BEGIN
- -- 检查输入参数不为空
- IF p_userName IS NULL OR p_age IS NULL OR p_introduce IS NULL THEN
- SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Input parameters cannot be NULL';
- END IF;
-
- -- 检查userName不以张、王、李、兆开头
- IF LEFT(p_userName, 1) = '张' OR LEFT(p_userName, 1) = '王'
- OR LEFT(p_userName, 1) = '李' OR LEFT(p_userName, 1) = '兆' THEN
- SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'userName cannot start with 张, 王, 李, or 兆';
- END IF;
-
- -- 插入语句,其中createDate和phone为随机数据,sex为随机枚举值
- INSERT INTO student (createDate, userName, phone, age, sex, introduce)
- VALUES (
- -- createDate: 随机日期(例如:过去10年内)
- DATE_ADD(NOW(), INTERVAL FLOOR(RAND() * (0 - 3650) + 0) DAY),
- -- userName: 使用传入的参数
- p_userName,
- -- phone: 随机电话号码(例如:以138开头的11位数字)
- CONCAT('138', LPAD(FLOOR(RAND() * 999999999), 9, '0')),
- -- age: 使用传入的参数
- p_age,
- -- sex: 随机性别(M, F, 或 O)
- ELT(1 + FLOOR(RAND() * 3), 'M', 'F', 'O'),
- -- introduce: 使用传入的参数
- p_introduce
- );
- END //
- DELIMITER ;
在上面的存储过程中,我们首先通过SIGNAL SQLSTATE语句来检查传入的参数是否为空或者userName是否以特定的字开头。如果检查不通过,则存储过程会抛出一个错误。如果检查通过,则会执行INSERT INTO语句来添加一条新的记录到student表中。
请注意,为了简化电话号码的生成逻辑,我在示例中使用了一个以138开头的随机9位数字。根据你的实际需求,你可能需要调整这部分逻辑以生成符合你所在地区电话号码规则的随机号码。
要调用这个存储过程并添加一条记录,你可以使用以下SQL语句:
CALL InsertStudent('SampleName', 25, 'This is a sample introduction.');
测试后,如果是对应的结果:
说明存储过程正确,判断结果无异常。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。