gpt4 book ai didi

java - SQL 类型说明符

转载 作者:行者123 更新时间:2023-11-29 04:32:52 25 4
gpt4 key购买 nike

大家好,我们有问题,不知道如何为日期类型添加类型说明符?我们尝试使用 %% 但这似乎不起作用。

    public class OrderDB implements OrderDBIF {
@Override
public Order create(Date date, int totalAmount, String deliveryStatus, Date deliveryDate, int invoiceId, int customerId) throws SQLException {
String sql = String.format("INSERT INTO Order (date, totalAmount, deliveryStatus, deliveryDate, invoiceId, customerId) VALUES "
+ "('%%', '%d', '%s', '%%', '%d', '%d')", date, totalAmount, deliveryStatus, deliveryDate, invoiceId, customerId);
try (Connection conn = DBConnection.getInstance().getDBcon();
Statement stmt = conn.createStatement()) {
stmt.executeUpdate(sql);
} catch(SQLException e) {
e.printStackTrace();
throw e;
}

最佳答案

使用准备好的语句:

String sql = "INSERT INTO Order "
+ "(date, totalAmount, deliveryStatus, deliveryDate, invoiceId, customerId) VALUES "
+ "(?,?,?,?,?,?)";
try (Connection conn = DBConnection.getInstance().getDBcon();
PreparedStatement ps = conn.prepareStatement(sql)) {
ps.setDate(1, date);
ps.setInt(2, totalAmount);
ps.setString(3, deliveryStatus);
ps.setDate(4, deliveryDate);
ps.setInt(5, invoiceId);
ps.setInt(6, customerId);
ps.executeUpdate();
} catch(SQLException e) {
e.printStackTrace();
throw e;
}

除了注意对 INSERT 中的所有值进行适当转义之外,准备好的语句还可以保护您免受 SQL 注入(inject)攻击。

关于java - SQL 类型说明符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43092593/

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