I want to generate a unique student ID. The format that I want is the last two digits of the current year plus 5 digits after that. For example: 2000001, 2000002, 2000003.. etc.. This is the extract of my code right now.
$pre = substr(strval(date("Y")),2);
$num = 1;
include "dbh.inc.php"; // this file merely creates the $conn variable that connects to mysql database.
$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
}
}
}
}
But I need to improve this because:
- It uses a goto (I want to avoid it)
- It seems overkill to prepare, bind, execute, etc everytime and query the database every loop.
- It is obviously slow.
Please let me know if there is a better way of doing this.