如何在PHP中生成学生证学号?怎么避免使用goto函数?

如何在PHP中生成学生证学号?怎么避免使用goto函数?

C++qingyu2020-12-06 14:47:491530A+A-

  如何在PHP中生成学生证学号?怎么避免使用goto函数?

  问题描述:

  我想生成一个唯一的学生证学号。我想要的格式是年份的最后两位数字,再加上5位数字。例如:2000001、2000002、2000003 等。

  以下是我的php代码:

$pre = substr(strval(date("Y")),2);
$num = 1;
include "dbh.inc.php"; 
$sql_cmd = "SELECT id FROM students WHERE id=?;";
$stmt = $conn->stmt_init();
if ($stmt) {
    $prepare = $stmt->prepare($sql_cmd);
    if ($prepare) {
        bind:
        $studentid = $pre . str_repeat('0', (4 - strlen($num)) ) . strval($num);
        $bind = $stmt->bind_param('s', $studentid);
        if ($bind) {
            $result = $stmt->execute();
            if ($result) {
                $num++;
                goto bind;
            }
            else {
                // insert student here using $studentid
            }
        }
    }
}

  我觉是上面代码需要改进:

  1.使用goto,我不想用这个函数.

  2.每次代码开始,绑定,执行等在每个循环中查询数据库带来很大的性能开销,显然很慢。

  是否有更好的方法呢?

  回答:

  1.可以在MySQL端生成新的学生证ID。

include "dbh.inc.php"; 

$sql = 
    "SELECT CONCAT("
        . "DATE_FORMAT(CURDATE(), '%y'), "
        . "LPAD(COALESCE(MAX(RIGHT(id, 5)) + 1, 1), 5, '0')"
    . ") AS new_id "
    . "FROM students";

$result = $conn->query($sql);
if ($result) {
    if ($row = $result->fetch_assoc()) {
       // insert student here using $row['new_id']
    }
}

  2.使用触发器,在插入数据时创建触发器。

DELIMITER //

CREATE TRIGGER students_tr_bi BEFORE INSERT ON students
FOR EACH ROW
BEGIN

    SET NEW.id = (
        SELECT CONCAT(
            DATE_FORMAT(CURDATE(), '%y'),
            LPAD(COALESCE(MAX(RIGHT(id, 5)) + 1, 1), 5, '0')
        ) FROM students
    );
      
END//

DELIMITER ;

-- Usage:
INSERT INTO students (name) VALUES ('John');
点击这里复制本文地址 欢迎来到大黄鸡源码分享网
qrcode

大黄鸡源码编程网 © All Rights Reserved.  
网站备案号:闽ICP备18012015号-4
Powered by Z-BlogPHP
联系我们| 关于我们| 广告联系| 网站管理