亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

JDBC如何映射java.sql.types類中MySQL中不存在的SQL類型?

JDBC如何映射java.sql.types類中MySQL中不存在的SQL類型?

猛跑小豬 2023-04-13 10:41:59
在java.sql.types類中,有一些類型很容易映射到 MySQL 類型。例如,VARCHAR在java.sql.types類中映射到VARCHARMySQL 中。但是,我不確定當 MySQL 中不存在類似類型時,java.sql.types 類中的類型如何JAVA_OBJECT映射到 MySQL 中的類型。在這種情況下,JDBC 會做什么?
查看完整描述

2 回答

?
FFIVE

TA貢獻1797條經驗 獲得超6個贊

如果 JDBC 驅動程序不支持您嘗試使用的類型 - 它會嘗試將其映射到支持的最接近的可能數據類型。如果它不能做到這一點 -SQLException被拋出。

JDBC 只是一個用于處理數據庫的接口。數據庫可能不支持 API 的某些部分。在這種情況下會發生什么完全取決于驅動程序的實現。這對所有 JDBC 驅動程序都很常見。


查看完整回答
反對 回復 2023-04-13
?
慕的地8271018

TA貢獻1796條經驗 獲得超4個贊

如您所知,每個 RDBMS 都會發布其 JDBC 實現,而 JDBC 會嘗試將 Java 的數據類型映射到數據庫的數據類型。如果沒有合適的映射選項,JDBC 將拋出java.sql.SQLException: Invalid column type.

根據 MySQL 的文檔,它不支持,但IBM Informix和OracleJAVA_OBJECT似乎支持它。

同時,如果你想插入一個 Java 對象到一個表中,你可以將它映射到BLOB.?假設您使用以下命令創建了一個表:

CREATE TABLE java_objects (?

? id INT AUTO_INCREMENT,?

? name varchar(128),?

? object_value BLOB,?

? primary key (id));

您可以使用此示例代碼插入您的對象。


public long insertAnObject(String className, Object javaObject)

{

? ? int id = -1;

? ? try

? ? {

? ? ? ? PreparedStatement preparedStatement = connection.prepareStatement("INSERT INTO java_objects(name, object_value) VALUES (?, ?)");


? ? ? ? // set input parameters

? ? ? ? preparedStatement.setString(1, className);

? ? ? ? preparedStatement.setObject(2, javaObject);

? ? ? ? preparedStatement.executeUpdate();


? ? ? ? // get the generated key for the id

? ? ? ? ResultSet resultSet = preparedStatement.getGeneratedKeys();

? ? ? ? if (resultSet.next())

? ? ? ? {

? ? ? ? ? ? id = resultSet.getInt(1);

? ? ? ? }


? ? ? ? resultSet.close();

? ? ? ? preparedStatement.close();

? ? ? ? return id;

? ? } catch (SQLException e)

? ? {

? ? ? ? e.printStackTrace();

? ? }


? ? return id;

}


查看完整回答
反對 回復 2023-04-13
  • 2 回答
  • 0 關注
  • 181 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號