gpt4 book ai didi

java - 如何在oracle中创建对象数据类型的列

转载 作者:行者123 更新时间:2023-12-02 08:57:35 28 4
gpt4 key购买 nike

我是一名网络开发人员。我有 Javascript 和 Typescript 背景。前几天我决定学习Oracle的JDBC。我使用 JavaFX 和 Oracle 创建了一个非常基本的 JDBC 项目。 (实际上我正在尝试模仿 Microsoft Azure)。我还有一个 Date 字段,它将从 JavaFx 内置 Datepicker 组件获取其值。以下是一些有用的信息:

表中的列:mybranches

  1. branch_name varchar(50)
  2. branch_created_on 日期
  3. branch_pulled_from varchar(50)

问题出在第二列,即 branch_created_on 字段。

这是我的java代码:DataService.java

import java.time.LocalDate;
...

public class DataService {
Connection con;
PreparedStatement pstmt;

static String branch_name="";
static LocalDate branch_created_on;
static String branch_pulled_from="";

DataService() {
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe","tiger","scott");
}
catch(Exception e){
System.out.println(e);
}
}

public void getValue() {
branch_name=AddNewBranchRecord.branchNameTextField.getText();
branch_created_on=AddNewBranchRecord.datePicker1.getValue();
branch_pulled_from=(String) AddNewBranchRecord.combo_box_1.getValue();
}

public void putValue() {
System.out.println("Branch name: "+branch_name);
System.out.println("Branch created on: "+branch_created_on);
System.out.println("Branch pulled from: "+branch_pulled_from);
}

public void insertRecord() {
getValue();
try {
pstmt=con.prepareStatement("INSERT INTO mybranches (branch_name,branch_created_on,branch_pulled_from) VALUES (?,?,?)");
pstmt.setString(1,branch_name);
pstmt.setObject(2,branch_created_on);
pstmt.setString(3,branch_pulled_from);
pstmt.execute();
} catch (SQLException ex) {
Logger.getLogger(DataService.class.getName()).log(Level.SEVERE, null, ex);
}
}
}

putValue 的输出也是正确的:

Branch name: 1000-test

Branch created on: 2020-02-11

Branch pulled from: master

但是当我调用 insertRecord 方法时,我得到了这个异常:

SEVERE: null

java.sql.SQLException: Invalid column type

at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)

...

如果我从数据库表以及 java 代码中删除该日期列,则不会出现此异常。如果我问了一个愚蠢的问题,我感到非常抱歉。我有 Angular 和 React 背景。请纠正我。

最佳答案

您并不是真的想使用setObject()

pstmt.setDate(2,branch_created_on); is giving me error: incompatible types: LocalDateCannot be converted to Date.

您可以将此与 @Christopher 的评论结合起来:

pstmt.setDate(2,java.sql.Date.valueOf(branch_created_on));

通过该更改以及硬编码的 Java 变量(而不是来自选择器),编译并运行并输出:

Branch name: 1000-test
Branch created on: 2020-02-11
Branch pulled from: master

在数据库中:

select * from mybranches;

BRANCH_NAME BRANCH_CREATED_ON BRANCH_PULLED_FROM
-------------------------------------------------- ------------------- --------------------------------------------------
1000-test 2020-02-11 00:00:00 master

关于java - 如何在oracle中创建对象数据类型的列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60400864/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com