SQL 时间戳插入添加额外的零

如何解决SQL 时间戳插入添加额外的零

我创建了下表 --

CREATE TABLE placed_order
(
    bill_number NUMBER(6) NOT NULL,customer_id NUMBER(6),order_time TIMESTAMP,paymentid NUMBER(6),total_bill_amount NUMBER(10,2),scheduled_delivery_time TIMESTAMP,address_id NUMBER(6),PRIMARY KEY (bill_number),FOREIGN KEY (customer_id) REFERENCES customer(customer_id),FOREIGN KEY (paymentid) REFERENCES payment_information(paymentid),FOREIGN KEY (address_id) REFERENCES delivery_address(address_id)
);

当我向表中插入以下值时 --

INSERT INTO placed_order 
VALUES (123456,1,'01-Feb-21 12:00:00 AM',34.56,'03-Feb-21 12:00:00 PM',1);

时间存储格式如下--

123456  1   01-FEB-21 12.00.00.000000000 AM 1   34.56   03-FEB-21 12.00.00.000000000 PM 1

当我尝试运行语句以对 SQL 进行操作(例如平均值)时,这会导致问题。例如,即使我想使用 to_date 将其转换为日期 --

select (TO_DATE(actual_delivery_time)) from delivery;

我收到以下错误 --

ORA-01830:日期格式图片在转换整个输入字符串之前结束
01830. 00000 - “日期格式图片在转换整个输入字符串之前结束”

我尝试检查 nls_database_parameters 中的时间戳格式,结果如下 -- NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM

如何确定附加零是什么以及为什么要附加它们?

解决方法

A TIMESTAMP 是一种二进制数据格式,包含 7-20 个字节(世纪、世纪年、月、日、时、分、秒,小数秒最多 6 个字节,小数秒最多 7 个字节)时区信息的字节);它没有格式。

'01-Feb-21 12:00:00 AM'NOT TIMESTAMP 数据类型;它是一个字符串文字,您依赖于从字符串到时间戳的隐式转换。 Oracle 将执行此操作,您的查询将有效:

INSERT INTO placed_order
VALUES (
  123456
  1,TO_TIMESTAMP(
    '01-Feb-21 12:00:00 AM',( SELECT value FROM NLS_SESSION_PARAMETERS WHERE parameter = 'NLS_TIMESTAMP_FORMAT' )
  ),1,34.56,TO_TIMESTAMP(
    '03-Feb-21 12:00:00 PM',1
);

但是,如果 NLS_TIMESTAMP_FORMAT 与您的字符串格式不匹配,则转换将失败。

查询应该怎么写?

你应该:

  • 显式使用 TO_TIMESTAMP( '01-Feb-21 12:00:00 AM','DD-MON-RR HH12:MI:SS AM' ) 而不是依赖隐式转换
  • 使用时间戳文字 TIMESTAMP '2021-02-01 00:00:00';或
  • 使用日期文字 DATE '2021-02-01'

例如:

INSERT INTO placed_order (
  bill_number,customer_id,order_time,paymentid,total_bill_amount,scheduled_delivery_time,address_id
) VALUES (
  123456
  1,TIMESTAMP '2021-02-01 00:00:00',TIMESTAMP '2021-02-03 12:00:00',1
);

如何格式化 TIMESTAMP 值?

如果您想用某种格式显示时间戳(请记住,TIMESTAMP 不以任何格式存储),那么您想使用 TO_CHAR 对其进行转换到一个可以有格式的字符串。

如果要将 TIMESTAMP 格式化为 YYYY-MM-DD 字符串,请使用:

SELECT TO_CHAR(actual_delivery_time,'YYYY-MM-DD') FROM delivery

例如,即使我想使用 to_date 将其转换为日期

TO_DATE 不会将 TIMESTAMP 转换为 DATE;它将字符串转换为 DATE。如果要将 TIMESTAMP 转换为 DATE 数据类型,请使用:

SELECT CAST(actual_delivery_time AS DATE) FROM delivery

(注意:DATE 数据类型也是二进制数据类型,不以任何格式存储;但是,您用来访问数据库的用户界面可能会选择显示使用 NLS_DATE_FORMAT 会话参数的日期。)

为什么显示小数秒?

我尝试检查 nls_database_parameters 中的时间戳格式,结果如下 -- NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM

谁能帮忙弄清楚额外的零是什么以及为什么要附加它们?

您正在显示二进制数据类型;您正在使用的用户界面试图提供帮助,而不是显示字节(人们可能难以理解),而是使用 NLS_TIMESTAMP_FORMAT 将二进制数据隐式转换为格式化字符串。

假设您的 NLS_TIMESTAMP_FORMATDD-MON-RR HH.MI.SSXFF AM,那么 FF 格式模型将显示小数秒;在这种情况下,您的小数秒为 0,它将显示达到时间戳的最大精度。

更改 NLS_TIMESTAMP_FORMAT,它将改变(某些)用户界面显示 TIMESTAMP 的方式(但是,它不会改变数据的存储方式)。>

是否可以在没有小数秒的情况下存储?

如果您想更改数据的存储方式,使其没有小数秒,则:

  • 为您使用的 TIMESTAMP 数据类型提供小数秒的显式精度并使用 TIMESTAMP(0);或
  • 使用 DATE 数据类型。

这两种数据类型都将使用 7 字节存储值,并将存储世纪、世纪年、月、日、小时、分钟和秒。两者差别不大;一个区别是时间戳将使用 NLS_TIMESTAMP_FORMAT 隐式格式化,日期使用 NLS_DATE_FORMAT 会话参数进行隐式格式化。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-