mysql - 从 MySQL 到 Oracle(NOW() 和自动增量 ID)

标签 mysql oracle timestamp auto-increment

我真的不知道如何问这个问题,但是......代码会帮助我:

/**
 * Languages table definition
 */
DROP TABLE IF EXISTS `languages`;
CREATE TABLE `languages`
(
    -- Common:
    `id`      INTEGER    NOT NULL AUTO_INCREMENT                COMMENT 'Unique registry identifier',
    `created` TIMESTAMP  NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT 'Registry creation TIMESTAMP',
    `updated` TIMESTAMP  NOT NULL DEFAULT NOW() ON UPDATE NOW() COMMENT 'Registry last update TIMESTAMP',
    `active`  BOOLEAN    NOT NULL DEFAULT TRUE                  COMMENT 'Virtual deletion flag',
    PRIMARY KEY (`id`),
    -- /Common
    `language_id`   INTEGER(2)  UNSIGNED NOT NULL COMMENT 'Language identifier',
    `language_code` VARCHAR(2)           NOT NULL COMMENT 'ISO 639-1 Code',
    `language_name` VARCHAR(20)          NOT NULL COMMENT 'Language name',
    -- Indexes
    UNIQUE KEY `language_id` (`language_id`)
) ENGINE=InnoDB CHARACTER SET 'latin1' COLLATE 'latin1_general_ci';

/**
 * Updates multilang field to UTF-8
 */
ALTER TABLE `languages` MODIFY `language_name` VARCHAR(20) CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';

/**
 * Assigns the current TIMESTAMP to the created field without user input
 */
CREATE TRIGGER `insert_languages` BEFORE INSERT ON `languages`
    FOR EACH ROW
SET NEW.created = NOW();

/* Insert a record */
INSERT INTO languages(language_id, language_code, language_name) VALUES(10, 'es', 'Español');

/* Update that record (after a few seconds) */
UPDATE languages SET language_name = 'Español (España)' WHERE language_id = 10;

检索 * WHERE language_id = 10 时,会收到两个不同的时间戳,而无需显式触及 TIMESTAMP 字段,而且在插入时我也不需要包含 ID。问题是:如何在 Oracle 中创建相同的行为?

最佳答案

  1. 您需要使用带有 BEFORE INSERT 触发器的序列来获得自动增量 ID
  2. 您需要使用 sysdatesystimestamplocaldate ...而不是 NOW() 来维护日期> 也在触发器中,BEFORE INSERTBEFORE UPDATE

关于mysql - 从 MySQL 到 Oracle(NOW() 和自动增量 ID),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6992315/

相关文章:

mysql - ruby on rails 数据库迁移

oracle - sql 加载器日志文件结果

php - 将时间戳插入 MySQL?

mysql - Node.js 与 knex + Mysql 重命名列时迁移错误导致默认值

MySQL 加载日期,格式为 mm/dd/yyyy

php - PHP 中的通用数据库连接

oracle - 编译或删除 Oracle 包时遇到问题

sql - 从 postgres 中的列创建时间戳

date - 在 presto 中将 bigint 转换为时间戳

mysql - 按相关性排序 MATCH AGAINST 或搜索确切的短语