MYSQL:每天改变当前id值成为sequence id

MYSQL: change current id value become sequence id each day

我想显示下面记录中的 id 值:

id      name            date
24811   Foo             2011-04-26
24812   Bar             2011-04-26
24813   Bars            2011-04-27

变成这样的格式:

date + Q + 4 digit ID sequence start from first ~ last

结果是:

id              name            date
20110426Q0001   Foo             2011-04-26
20110426Q0002   Bar             2011-04-26
20110427Q0001   Bars            2011-04-27 

但是我只有一半的疑问,4位数字是怎么算的?

SELECT REPLACE( CONCAT( DATE( Inspection_datetime ) ,'Q',/*missing this query..*/),'-','') AS id,
       name,date
FROM mytable

尝试以下答案后:

row @g:= `date`         id              Model           Serial      Lot_no  Inspection_datetime
1   2011-01-31 07:44:21 20110131Q0001   KW-HDR81BTJD    176X0099    010A    2011-01-31 07:44:21
1   2011-01-31 08:31:31 20110131Q0001   KW-HDR81BTJD    176X0098    010A    2011-01-31 08:31:31
1   2011-01-31 08:34:57 20110131Q0001   KW-HDR81BTJD    176X0065    010A    2011-01-31 08:34:57
1   2011-01-31 08:46:43 20110131Q0001   KW-HDR81BTJD    176X0050    010A    2011-01-31 08:46:43

您可以使用用户定义的变量

select 
@r:= case when @g = date then @r +1 else 1 end rownum,
@g:= date,
REPLACE( CONCAT( 
  DATE(date) ,
  'Q'
  ,lpad(@r,4,'0')
  ),'-','') AS id,
name,
date
from mytable
cross join (select @g=null, @r:= 0) t
order by date

DEMO

如果你只关心日期部分而不关心时间部分那么你可以这样做

select 
@r:= case when @g = date(date) then @r +1 else 1 end rownum,
@g:= date(date),
REPLACE( CONCAT( 
  DATE(date) ,
  'Q'
  ,lpad(@r,4,'0')
  ),'-','') AS id,
name,
date
from mytable
cross join (select @g=null, @r:= 0) t
order by date

DEMO

我不知道为什么 Khalid 的两个查询在我的 Mysql 中都不起作用。 即使我在 sqlfiddle 上尝试过,它也能工作,但它不在我的数据库中。 一个星期后,我为这个问题发疯了,我得到了答案:

我正在使用 Khalid 的第二个答案,然后尝试删除:

cross join (select @g=null, @r:= 0) t

然后在select之前添加:

set @g=null,@r:= 0;