创建学号与年和自动增加的值


create Student ID number with year and auto incremented value

我创建了一个由文本和自动增加的值组成的学生id号,如:KP0001 - KP9999,它将再次重置为KP0001,这将导致重复的id号。我把它改成:2013-00001,但它不工作,我不知道为什么。

这是我尝试过的:

text  id
KP    1
KP    2
KP    3
SELECT * ,concat(text,LPAD(id,4,'0')) as stud_id FROM students

我想将文本更改为每年更新的年份。谢谢,米尔斯

试试这个

SELECT
  *,
  concat(YEAR(NOW()),'-',LPAD(id,5,'0')) as stud_id
FROM students

SQL Fiddle Demo

输出
id  text    stud_id
--------------------
1   KP      2013-00001
2   KP      2013-00002
3   KP      2013-00003

你可以使用这个更新查询

UPDATE students AS s
LEFT JOIN(
        SELECT 
        *
        FROM students
    ) AS l ON l.id = s.id
SET s.text = concat(YEAR(NOW()),'-',LPAD(l.id,5,'0'))