百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

避坑指南:KingbaseES Oracle模式中隐藏的"双Date"玄机

moboyou 2025-04-09 13:23 29 浏览

在数据库开发中,日期时间处理是高频操作场景。当您从Oracle迁移到国产数据库时,是否遇到过这样的困惑:为什么在KingbaseES中创建的两个Date字段,一个显示精确到秒,另一个却只有年月日? 这背后暗藏了KingbaseES对两大数据库生态的深度兼容智慧。今天我们将揭开这个"双Date类型"的神秘面纱。


一、从Oracle到PostgreSQL的Date进化论

Oracle Date
传统Oracle数据库的DATE类型设计为 **"日期+时间"** 的复合体,即使只存入'2023-01-01',底层仍会存储为精确到秒的时间戳(如 2023-01-01 00:00:00)。

PostgreSQL Date
PG生态则采用"纯日期"设计理念,DATE类型仅存储年月日信息,时间处理需额外使用TIMESTAMP类型。

国产化兼容难题
当KingbaseES的Oracle兼容模式需要同时支持两种生态时,创新性地通过 **"双Date机制"** 实现完美兼容,这也是引发文章开头现象的核心原因。


二、解剖KingbaseES的"双Date"黑科技

通过系统表查询,我们可以直观看到两个Date类型的共存:

sql
test=# SELECT typname, typnamespace::regnamespace 
       FROM sys_type 
       WHERE typname='date';

 typname | typnamespace  
---------+--------------
 date    | pg_catalog
 date    | sys
  • sys.date
    专为Oracle兼容设计,支持 **"年月日+时分秒"** 存储,对应Oracle的DATE类型
  • pg_catalog.date
    遵循PG标准,仅存储日期信息

三、实战验证:一个字段两种效果

通过设置优先级和格式化参数,我们可以复现神奇现象:

sql
-- 确认schema搜索路径(sys优先)
test=# SELECT current_schemas(true);
 current_schemas 
-----------------
 {sys,pg_catalog,...}

-- 设置时间显示格式(兼容Oracle)
test=# SET nls_date_format='yyyy-mm-dd hh24:mi:ss';

-- 创建对比测试表
test=# CREATE TABLE t_date(
  id1 pg_catalog.date,  -- PG原生Date
  id2 date              -- sys.Date(Oracle兼容)
);

-- 插入相同字面值数据
test=# INSERT INTO t_date VALUES('2023-08-08','2023-08-08');

-- 见证差异化输出
test=# SELECT * FROM t_date;
      id1       |        id2        
----------------+--------------------
 2023-08-08     | 2023-08-08 00:00:00

关键发现
相同字面值'2023-08-08'在不同类型的Date字段中,sys.date自动补全时间信息,而pg_catalog.date保持纯日期特性。


四、避坑指南:开发中的黄金法则

  1. 显式指定类型
    建表时推荐使用sys.date或pg_catalog.date显式声明,避免隐式类型选择
  2. sql
  3. -- 推荐写法 CREATE TABLE orders ( create_time sys.date, -- 带时间的Oracle风格 expire_date pg_catalog.date -- 纯日期 );
  4. 格式化参数必设项
    当使用sys.date时,建议设置nls_date_format保证显示预期:
  5. sql
  6. -- 会话级设置 SET nls_date_format='yyyy-mm-dd hh24:mi:ss'; -- 永久生效 ALTER SYSTEM SET nls_date_format='yyyy-mm-dd hh24:mi:ss';
  7. 迁移检查清单
    从Oracle迁移时,需批量转换Date字段类型:
  8. sql
  9. -- 查询所有Date字段 SELECT column_name, data_type FROM information_schema.columns WHERE data_type = 'date'; -- 批量修改为sys.date ALTER TABLE orders ALTER COLUMN create_time TYPE sys.date;

五、背后的国产化兼容哲学

KingbaseES通过 **"模式优先权"** 机制实现生态兼容:

  1. 当应用连接指定为Oracle模式时,自动优先使用sys模式下的对象
  2. 通过current_schemas()顺序控制类型解析优先级
  3. 提供nls_date_format等兼容参数,降低迁移成本

这种设计既保留了PostgreSQL的扩展能力,又实现了对Oracle的深度兼容,彰显了国产数据库在生态融合上的匠心精神。


结语
理解"双Date机制"不仅能避免开发中的隐蔽问题,更能帮助我们善用KingbaseES的兼容特性。下次当您看到时间显示出现"时分秒幽灵"时,请记得调出这篇文章一探究竟。关于更多国产数据库的隐藏技巧,欢迎持续关注公众号【金仓拾光集】的技术解密!

相关推荐

php宝塔搭建部署实战服务类家政钟点工保姆网站源码

大家好啊,我是测评君,欢迎来到web测评。本期给大家带来一套php开发的服务类家政钟点工保姆网站源码,感兴趣的朋友可以自行下载学习。技术架构PHP7.2+nginx+mysql5.7+JS...

360自动收录简介及添加360自动收录功能的详细教程

以前我们都是为博客站点添加百度实时推送功能,现在360已经推出了自动收录功能,个人认为这个功能应该跟百度的实时推送功能差不多,所以我们也应该添加上这个功能,毕竟360在国内的份额还是不少的。360自动...

介绍一个渗透测试中使用的WEB扫描工具:Skipfish

Skipfish简介Skipfish是一款主动的、轻量级的Web应用程序安全侦察工具。它通过执行递归爬取和基于字典的探测来为目标站点准备交互式站点地图。该工具生成的最终报告旨在作为专业Web应用程序安...

好程序员大数据培训分享Apache-Hadoop简介

好程序员大数据培训分享Apache-Hadoop简介  好程序员大数据培训分享Apache-Hadoop简介,一、Hadoop出现的原因:现在的我们,生活在数据大爆炸的年代。国际数据公司已经预测在20...

LPL比赛数据可视化,完成这个项目,用尽了我的所有Python知识

LPL比赛数据可视化效果图完成这个项目,我感觉我已经被掏空了,我几乎用尽了我会的所有知识html+css+javascript+jQuery+python+requests+numpy+mysql+p...

网站被谷歌标记“有垃圾内容”但找不到具体页面?

谷歌的垃圾内容判定机制复杂,有时违规页面藏得深(如用户注册页、旧测试内容),或是因第三方插件漏洞被注入垃圾代码,导致站长反复排查仍毫无头绪。本文提供一套低成本、高执行性的解决方案。你将学会如何利用谷歌...

黑客必学知识点--如何轻松绕过CDN,找到真实的IP地址

信息收集(二)1、cms识别基础为什么要找CMS信息呢?因为有了CMS信息之后,会给我们很多便利,我们可以搜索相应CMS,有没有公开的漏洞利用根据敏感文件的判断:robots.txt文件robots....

Scrapy 爬虫完整案例-提升篇

1Scrapy爬虫完整案例-提升篇1.1Scrapy爬虫进阶案例一Scrapy爬虫案例:东莞阳光热线问政平台。网站地址:http://wz.sun0769.com/index.php/que...

如何写一个疯狂的爬虫!

自己在做张大妈比价(http://hizdm.com)的时候我先后写了两个版本的爬虫(php版本和python版本),虽然我试图将他们伪装的很像人但是由于京东的价格接口是一个对外开放的接口,如果访问频...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Python爬虫高级之JS渗透登录新浪微博 | 知了独家研究

小伙伴们看到标题可能会想,我能直接自己登陆把登陆后的cookie复制下来加到自定义的请求头里面不香嘛,为什么非要用python模拟登录的过程?如果我们是长期爬取数据,比如每天早上中午和晚上定时爬取新浪...

使用Selenium实现微博爬虫:预登录、展开全文、翻页

前言想实现爬微博的自由吗?这里可以实现了!本文可以解决微博预登录、识别“展开全文”并爬取完整数据、翻页设置等问题。一、区分动态爬虫和静态爬虫1、静态网页静态网页是纯粹的HTML,没有后台数据库,不含程...

《孤注一掷》关于黑客的彩蛋,你知道多少?

电影总是能引发人们的好奇心,尤其是近日上映的电影《孤注一掷》。这部电影由宁浩监制,申奥编剧执导,是一部反诈骗犯罪片。今天给大家讲解一下影片潘生用的什么语言,以及写了哪些程序。揭秘影片中的SQL注入手法...

python爬虫实战之Headers信息校验-Cookie

一、什么是cookie上期我们了解了User-Agent,这期我们来看下如何利用Cookie进行用户模拟登录从而进行网站数据的爬取。首先让我们来了解下什么是Cookie:Cookie指某些网站为了辨别...

「2022 年」崔庆才 Python3 爬虫教程 - urllib 爬虫初体验

首先我们介绍一个Python库,叫做urllib,利用它我们可以实现HTTP请求的发送,而不用去关心HTTP协议本身甚至更低层的实现。我们只需要指定请求的URL、请求头、请求体等信息即...