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

标签 mysql oracle

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

X-A 字母,说明原产国,例如S 代表西类牙,Z 代表津巴布韦等(我们只有五个原籍国)

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

我的问题是如何在 MySQL 中生成 9999999 的部分。在 Oracle 中,它会是

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

最佳答案

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

关于MySQL自动增量加上一列中的字母数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2380923/

相关文章:

php - 如何在 PhalconPHP 中运行 RAW SQL 查询

java - 在 Oracle 中构建图像数据库 - 电子商务风格的界面可行吗?

mysql - 从亚马逊ubuntu 10.04实例连接到Windows Server 2003中的Oracle数据库

java - 准备好的语句 - 使用函数作为 where 子句的一部分

oracle - 自定义 Oracle AWR 报告

php - 在表名中动态插入数据

php - MySQL 的最佳配置? InnoDB 和 MyISAM

mysql - 如何在安装在 MySql 4 之上的 MySql 5 上启用 inno-db 支持?

mysql - 如何将 XML 转换为 SQL?

mysql - 当我尝试此语法时,我在 MySql 中遇到错误 #1241