PreparedStatement的setNull

本文详细解释了在Java中如何正确使用PreparedStatement的setNull方法来设置SQL语句中的NULL值。作者通过个人经验分享,强调了根据不同字段类型选择正确的NULL类型的重要性,并提供了具体的示例代码。

PreparedStatement的setNull在使用时候需要注意,我以前以为任何类别都可以用这个方法来设置null值,今天发现我的想法是完全不对的,不同的类型要使用不同的不同NULL的类型,后来又自己研究了api文档,原来是我看的不够仔细

方法原型:PreparedStatement.setNull(int index, int sqlType),这里说的很清楚,第二个参数使用sqlType,应该用java.sql.Types中的类型来设置。

比如,若设置某个类型为Double字段为空,则代码为:setNull(1,Types.DOUBLE);

若设置某个类型为Date字段为空,则代码为:setNull(1,Types.DATE);

这里有一位已经写的比较清楚了,请看:http://hi.baidu.com/gstripe/blog/item/d37f8226c47771168b82a107.html

`PreparedStatement.setObject` 方法是 Java 中用于向 `PreparedStatement` 对象中的占位符(`?`)设置参数的重要方法。以下是关于该方法的使用、功能、注意事项等相关信息: ### 使用方法 以下是使用 `setObject` 方法为 SQL 语句设置参数的示例代码: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class SetObjectExample { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/your_database"; String username = "your_username"; String password = "your_password"; String sql = "SELECT * FROM tableName WHERE id = ? AND Name = ?"; Object[] params = {1, "John"}; try (Connection connection = DriverManager.getConnection(url, username, password); PreparedStatement preparedStatement = connection.prepareStatement(sql)) { for (int i = 0; i < params.length; i++) { // setObject 用于设置占位符的参数,占位符(?)从 1 开始,但是数组从 0 开始 preparedStatement.setObject(i + 1, params[i]); } // 执行查询等操作 // ResultSet resultSet = preparedStatement.executeQuery(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 在上述代码中,通过 `for` 循环遍历 `params` 数组,并使用 `setObject` 方法将数组元素依次设置到 SQL 语句的占位符中,占位符从 1 开始编号,而数组索引从 0 开始,所以使用 `i + 1` 作为 `setObject` 方法的第一个参数 [^3]。 ### 功能 - **防止 SQL 注入**:`PreparedStatement` 对象可以防止 SQL 注入,而 `Statement` 不能。在实际开发中,应优先使用 `PreparedStatement` 及其 `setObject` 方法,避免使用 `Statement` [^1]。 - **参数类型自动转换**:使用 `setObject` 方法填充占位符时,该方法会判断实际传入的参数类型,进行参数转换。例如,如果传入的是 `String` 类型,会在参数开始和结尾追加单引号 `'`;如果传入的是 `java.sql.Date` 类型,还会将时间戳自动转为字符串 [^2]。 ### 注意事项 - **参数不能为 `null`**:在使用 `setObject` 方法传参时,要注意传入的参数不能为 `null`,否则可能会引发异常。需要在代码中进行 `null` 值的检查和处理 [^3]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值