# 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 操作
* 插入日期
```sql
insert into table (create_time) values(to_date('2024-5-08 12:20:33','YYYY-MM-DD HH24:MI:SS'));
```
* 查询日期
```sql
select to_char(create_time,'YYYY-MM-DD HH24:MI:SS') from table;
```
* 修改日期
```sql
update table set create_time=to_date('2023-09-25 18:30:38','yyyy-mm-dd hh24:mi:ss') where id=1;
```
# 3 主键自增
* 首先,创建一个序列来生成唯一的数字ID
```sql
CREATE SEQUENCE my_seq START WITH 1 INCREMENT BY 1;
```
* 然后,在我们的数据表中创建一个触发器来捕获插入操作,并把所需的唯一 ID 填到对应字段里。
```sql
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;
```
* 删除序列
```sql
DROP SEQUENCE my_sequence;
```
* 删除不同模式下的特定名称的触发器
```sql
DROP TRIGGER schema_name.trigger_name;
```
# 4 分页查询
* 每页五行数据,查找第二页
```sql
SELECT "id", "name"
FROM "person"
ORDER BY "id"
OFFSET 1*5 ROWS FETCH NEXT 5 ROWS ONLY;
```