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
如果你只关心日期部分而不关心时间部分那么你可以这样做
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
我不知道为什么 Khalid 的两个查询在我的 Mysql
中都不起作用。
即使我在 sqlfiddle
上尝试过,它也能工作,但它不在我的数据库中。
一个星期后,我为这个问题发疯了,我得到了答案:
我正在使用 Khalid 的第二个答案,然后尝试删除:
cross join (select @g=null, @r:= 0) t
然后在select之前添加:
set @g=null,@r:= 0;
我想显示下面记录中的 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
如果你只关心日期部分而不关心时间部分那么你可以这样做
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
我不知道为什么 Khalid 的两个查询在我的 Mysql
中都不起作用。
即使我在 sqlfiddle
上尝试过,它也能工作,但它不在我的数据库中。
一个星期后,我为这个问题发疯了,我得到了答案:
我正在使用 Khalid 的第二个答案,然后尝试删除:
cross join (select @g=null, @r:= 0) t
然后在select之前添加:
set @g=null,@r:= 0;