oracle 數據庫字段類型為NUMBER(5,2)時,并且數據庫值為0.1,為什么Java執行SQL查出來時為“.1“?

在 Oracle 數據庫中,當字段類型為 NUMBER(5,2) 且存儲的值為 0.1 時,Java 程序查詢結果可能顯示為 ".1"(省略前導零),這是由 Oracle JDBC 驅動默認的數字格式化行為 導致的。以下是原因分析和解決方案:


原因分析

  1. Oracle 的 NUMBER 類型特性

    • NUMBER(5,2) 表示最多 5 位數字,其中 2 位是小數(范圍:-999.99999.99)。
    • 當存儲 0.1 時,實際存儲的是精確值 0.10(補全小數位到 2 位),但查詢時會省略末尾的零。
  2. JDBC 驅動的默認格式化

    • Oracle JDBC 驅動(如 ojdbc8)在返回 NUMBER 類型時,默認會去除前導零(如 0.1".1"),這是為了減少不必要的字符。
  3. Java 數據類型映射

    • NUMBER 字段會被 JDBC 驅動映射為 BigDecimalDouble,而 BigDecimal.toString() 默認會省略前導零。

解決方案

方法1:在 SQL 查詢中顯式格式化

使用 TO_CHAR 函數強制保留前導零:

SELECT TO_CHAR(your_number_column, '0.00') FROM your_table;

結果會固定為 "0.10"(字符串類型)。

方法2:在 Java 中格式化結果

將查詢結果轉換為 BigDecimal 并手動格式化:

import java.math.BigDecimal;
import java.text.DecimalFormat;BigDecimal value = resultSet.getBigDecimal("your_column");
DecimalFormat df = new DecimalFormat("0.00"); // 強制保留兩位小數
String formattedValue = df.format(value);     // 輸出 "0.10"
**方法3:修改 JDBC 驅動的格式化行為 **

在連接字符串中添加參數,關閉驅動的默認格式化:

String url = "jdbc:oracle:thin:@localhost:1521:ORCL?oracle.jdbc.defaultNumericChar=true";

注意此參數可能因驅動版本不同而失效,建議優先使用方法1或2。

方法4:直接處理結果集

如果查詢結果已經是字符串形式的 ".1",可以手動補零:

String rawValue = resultSet.getString("your_column");
if (rawValue.startsWith(".")) {rawValue = "0" + rawValue; // ".1" → "0.1"
}

驗證數據庫實際存儲值

執行以下 SQL,確認數據庫中實際存儲的值:

SELECT DUMP(your_number_column) FROM your_table;
  • 輸出示例:Typ=2 Len=2: 193,11(表示存儲的是 0.10,但查詢時被格式化)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/77255.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/77255.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/77255.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

3月AI論文精選十篇

1. Feature-Level Insights into Artificial Text Detection with Sparse Autoencoders[1] 核心貢獻:通過稀疏自編碼器揭示AI生成文本的檢測特征,提出基于特征分布的鑒別方法。研究發現,AI文本在稀疏編碼空間中呈現獨特的"高頻低幅"…

STM32在裸機(無RTOS)環境下,需要手動實現隊列機制來替代FreeRTOS的CAN發送接收函數

xQueueSendToBackFromISR(ecuCanRxQueue, hcan->pRxMsg, &xHigherPriorityTaskWoken),xQueueReceive(mscCanRxQueue,&mscRxMsg,0)和xQueueSendToBack(mscCanTxQueue, &TxMessageTemp, 0 )這3個函數,在裸機下實現: 在裸機&…

使用PX4,gazebo,mavros為旋翼添加下視的相機(仿真采集openrealm數據集-第一步)

目錄 一.方法一(沒成功) 1.運行PX4 2.運行mavros通訊 3.啟動仿真世界和無人機 (1)單獨測試相機 (2)make px4_sitl gazebo啟動四旋翼iris無人機 二.方法二(成功) 1.通過 rosl…

7、nRF52xx藍牙學習(nrf_gpiote.c庫函數學習)

續前一篇文章。 3、nrfx_gpiote_in_event_enable void nrfx_gpiote_in_event_enable(nrfx_gpiote_pin_t pin, bool int_enable) {NRFX_ASSERT(nrf_gpio_pin_present_check(pin));NRFX_ASSERT(pin_in_use_by_gpiote(pin));if (pin_in_use_by_port(pin)){nrf_gpiote_polarity_t…

Java 實現插入排序:[通俗易懂的排序算法系列之三]

引言 大家好!歡迎繼續關注我的排序算法系列。今天,我們要學習的是另一種非常基礎且重要的排序算法——插入排序 (Insertion Sort)。 插入排序的思路非常貼近我們日常整理撲克牌的方式,理解起來相對自然。雖然它在最壞情況下的效率不高,但在某些特定場景下,它的表現甚至優…

Java的spring boot項目編譯成功啟動報錯

問題現象:spring boot項目,候刪除一些無用代碼后,build成功,啟動時報錯:找不到java.util.Map或者其他對象(用Lombok注解Data)中的字段屬性找不到等錯誤。解答: 常見是Lombok版本問題…

PyTorch參數管理詳解:從訪問到初始化與共享

本文通過實例代碼講解如何在PyTorch中管理神經網絡參數,包括參數訪問、多種初始化方法、自定義初始化以及參數綁定技術。所有代碼可直接運行,適合深度學習初學者進階學習。 1. 定義網絡與參數訪問 1.1 定義單隱藏層多層感知機 import torch from torch…

基于springboot+vue的課程管理系統

一、系統架構 前端:vue | element-ui 后端:springboot | mybatis-plus 環境:jdk1.8 | mysql8 | maven | node v16.20.2 | idea 二、代碼及數據 三、功能介紹 01. 登錄 02. 管理員-首頁 03. 管理員-系管理 04. 管理員-專業管理 05. 管…

ssh密鑰連接遠程服務器并用scp傳輸文件

ssh密鑰連接遠程服務器 私鑰的權限必須是600chmod 600 id_rsa連接時在命令中加上私鑰的地址ssh -i PATH_to_id_rsa usernameip -p port scp -P port -i PATH_to_id_rsa file usernameip:PATH

ElasticSearch遷移數據

一、查詢索引 1、查詢所有索引 curl --user elastic:123456 -XGET "http://localhost:19200/_cat/indices?v&sindex" 2、查詢索引配置 以索引名稱hello為例 curl --user elastic:123456 -XGET "http://localhost:19200/hello/_settings?pretty" 3…

【Unity】animator檢測某state動畫播放完畢方法

博主對動畫系統很不熟,可能使用的方法比較曲折,但是我確實沒找到更有效的方法了。 unity的這個animator在我看來簡直有毛病啊,為什么那么難以獲取某狀態動畫的信息呢??? 想要知道動畫播完沒有只有用norma…

Jmeter 插件【性能測試監控搭建】

1. 安裝Plugins Manager 1.1 下載路徑: Install :: JMeter-Plugins.org 1.2 放在lib/ext目錄下 1.3 重啟Jmeter,會在菜單-選項下多一個 Plugins Manager菜單,打開即可對插件進行安裝、升級。 2. 客戶端(Jmeter端) 2.1 安裝plugins manager…

ollama+open-webui本地部署自己的模型到d盤+兩種open-webui部署方式(詳細步驟+大量貼圖)

一、ollama準備 1.官網下載ollama:https://ollama.com/download 2.在 d 盤創建 ollama 文件夾,把軟件包放進去 3.管理員身份運行黑窗口 win r 彈出運行窗口 輸入 cmd 后, ctrl shift 回車,以管理員身份打開 3.切換到 d 盤&a…

(學習總結33)Linux Ext2 文件系統與軟硬鏈接

Linux Ext2 文件系統與軟硬鏈接 理解硬件磁盤、服務器、機柜、機房磁盤物理結構磁盤的邏輯結構實際過程 CHS 與 LBA 地址轉換 引入文件系統引入 " 塊 " 概念引入 " 分區 " 概念引入 " inode " 概念 ext2 文件系統宏觀認識Block Group 塊組與其內…

Go語言sync.Mutex包源碼解讀

互斥鎖sync.Mutex是在并發程序中對共享資源進行訪問控制的主要手段,對此Go語言提供了非常簡單易用的機制。sync.Mutex為結構體類型,對外暴露Lock()、Unlock()、TryLock()三種方法,分別用于阻塞加鎖、解鎖、非阻塞加鎖操作(加鎖失敗…

SQL注入流量分析

免責聲明:本文僅作分享 ~ 目錄 SQL注入流量分析 特征: sqlmap注入類型 漏洞環境搭建 error_sql: bool_sql: time_sql: union_sql: Stacked Queries: Inline Queries: SQL注入流量分析 https://www.freebuf.com/column/161797.html SQLMAP攻擊…

Linux 時間同步工具 Chrony 簡介與使用

一、Chrony 是什么? chrony 是一個開源的網絡時間同步工具,主要由兩個組件組成: chronyd:后臺服務進程,負責與時間服務器交互,同步系統時鐘。chronyc:命令行工具,用于手動查看或修…

Flutter:Flutter SDK版本控制,fvm安裝使用

1、首先已經安裝了Dart,cmd中執行 dart pub global activate fvm2、windows配置系統環境變量 fvm --version3、查看本地已安裝的 Flutter 版本 fvm releases4、驗證當前使用的 Flutter 版本: fvm flutter --version5、切換到特定版本的 Flutter fvm use …

Vue 項目中的package.json各部分的作用和用法的詳細說明

1. 基本信息 {"name": "my-vue-app","version": "1.0.0","description": "A Vue.js project","author": "Your Name <your.emailexample.com>","license": "MIT"…

Linux網絡編程——TCP通信的四次揮手

一、前言 上篇文章講到了TCP通信建立連接的“三次握手”的一些細節&#xff0c;本文再對TCP通信斷開連接的“四次揮手”的過程做一些分析了解。 二、TCP斷開連接的“四次揮手” 我們知道TCP在建立連接的時需要“三次握手”&#xff0c;三次握手完后就可以進行通信了。而在通…