MySQL自动增量加上一列的字母数字

时间:2010-03-04 16:32:42

标签: mysql oracle

我是来自Oracle的MySQL新手。我需要在一列中创建一个主键,但格式如下。

X-A来自原产国的信件,例如S为西班牙,Z为津巴布韦e.tc(我们只有五个来源国)

YYYYMMDD - 该格式的日期,
9999 - 4位数的办公室代码 9999999 - 来自Oracle中序列的7个右填充序列号(MySQL中的自动增量)
这给了我一个主键,如Z2010013150110000001作为主键。

我的问题是如何在MySQL中生成9999999的一部分。在Oracle中,它本来就是

select 'Z'||to_char(sysdate, 'YYYYMMDD')|| 5011||cust_id.nextval from dual;

1 个答案:

答案 0 :(得分:3)

auto_increment不能只是字段的一部分,因此单个列可能是一个字符。那怎么样:

CREATE TABLE xxxxx (
id int unsigned not null auto_increment,
rest_of_that_key char(xx) not null,
// other goodies
PRIMARY KEY (id)
);

然后你可以SELECT CONCAT(rest_of_that_key, LPAD(id, 7, '0')) AS full_key FROM xxxxx


甚至更好,因此您可以使用这些办公代码和日期来过滤数据:

CREATE TABLE xxxxx (
id int unsigned not null auto_increment,
country_code char(1) not null,
sysdate date not null,
office_code smallint unsigned not null,
// other goodies
PRIMARY KEY (id),
KEY country_code (country_code)
// etc, index the useful stuff
);

然后你可以使用SELECT CONCAT(country_code, DATE_FORMAT(sysdate, '%Y%m%d'), office_code, LPAD(id, 7, '0')) AS full_key FROM xxxxx甚至扔进WHERE office_code = 1256 AND sysdate >= '2010-01-01'而不必以某种方式解析那个巨大的字符串。

如果您确实需要将这个巨大的字符串作为单字段主键,那么您将自己手动增加内容。我仍然不建议这样做,MySQL 真的喜欢它的PK是数字。