我创建了一个由文本和自动增加的值组成的学生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'))