【问题标题】:MySQL auto increment plus alphanumerics in one columnMySQL 自动增量加上一列中的字母数字
【发布时间】:2011-01-23 18:25:15
【问题描述】:

我是来自 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;

【问题讨论】:

  • 有人不懂规范化...

标签: mysql oracle


【解决方案1】:

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 是数字的。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-03-27
    • 2011-05-01
    • 2013-02-11
    • 2011-09-25
    • 1970-01-01
    相关资源
    最近更新 更多