Oracle数据库中日期的操作、主键自增与分页查询

1 oracle数据库中的日期

在Oracle数据库中,DATE类型的存储范围为公历前4712年1月1日至公历后 9999年12月31日,这个日期范围也被称为Oracle库中支持的“Gregorian calendar”。尽管在实际应用中一般不会涉及到这么早的历史记录和太远的未来,但这个日期范围可以覆盖现代时期所有的时间日期需求。

需要注意的是,Oracle DATE类型使用 7 个字节来存储它的值,其中包括世纪、年、月、日、小时、分钟和秒。而当你使用类似 “SELECT SYSDATE FROM DUAL;” 的语句查询数据库中的当前日期时,其返回结果可能会因为客户端的设置略有差异,但是总体来说其格式都是YYYY-MM-DD HH24:MI:SS形式的日期时间字符串。

对于TIMESTAMP类型,它能够存储更加精确的时间戳信息(包括毫秒/微秒/纳秒),一般用于要求高精度的时间计算和比较场景,但其存储范围只能覆盖从公元1970年1月1日00:00:01到公元9999年12月31日23:59:59.999999(六位小数)。

2 操作

  • 插入日期
insert into table (create_time) values(to_date('2024-5-08 12:20:33','YYYY-MM-DD HH24:MI:SS'));
  • 查询日期
select to_char(create_time,'YYYY-MM-DD HH24:MI:SS') from table;
  • 修改日期
update table set create_time=to_date('2023-09-25 18:30:38','yyyy-mm-dd hh24:mi:ss') where id=1;

3 主键自增

  • 首先,创建一个序列来生成唯一的数字ID
CREATE SEQUENCE my_seq START WITH 1 INCREMENT BY 1;
  • 然后,在我们的数据表中创建一个触发器来捕获插入操作,并把所需的唯一 ID 填到对应字段里。
CREATE TRIGGER my_table_trigger BEFORE INSERT ON schema_name.my_table FOR EACH ROW
BEGIN
  SELECT my_seq.nextval INTO :new.id FROM dual;
END;
  • 删除序列
DROP SEQUENCE my_sequence;
  • 删除不同模式下的特定名称的触发器
DROP TRIGGER schema_name.trigger_name;

4 分页查询

  • 每页五行数据,查找第二页
SELECT "id", "name"
FROM "person"
ORDER BY "id"
OFFSET 1*5 ROWS FETCH NEXT 5 ROWS ONLY;

你可能感兴趣的:(数据库,oracle,sql)