Hibernate4报错java.lang.NullPointException, JdbcServiceImpl.configure(JdbcServiceImpl.java:207)

本文介绍了一种解决Hibernate中出现NullPointException的方法,通过在配置文件中加入特定属性避免因咨询JDBC元数据来确定默认设置值而产生的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报错堆栈如下:

Caused by: java.lang.NullPointException

at org.hibernate.engine.jdbs.internal.JdbcServiceImpl.configure(JdbcServiceImpl.java:207)

at org.hibernate.service.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:76)

......


解决方案:

在hibernate配置中加上如下属性:

<prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>

hibernate.temp.use_jdbc_metadata_defaults 的意思是(如下摘自互联网):
这里是源码注释的大概意思

it is used to control whether we should consult the JDBC metadata to determine
certain Settings default values; it is useful to *not* do this when the database
may not be available (mainly in tools usage).

它是用来控制是否应该向JDBC元数据来确定某些设置默认值,
在数据库某些服务不可用的设置为 *不*,在某些工具中开发是非常有用的

还有其他的注释说,这个这是对应的功能还在开发中,所以这里都是设置为FALSE的
TRUE时的功能还在考虑开发中


Java 编程中,`Stream.forEach()` 方法用于遍历流中的每个元素并对它们执行给定的操作。如果遇到 `java.lang.NullPointerException` 错误,则通常意味着程序试图访问空对象引用的内容或调用其方法。当涉及到 Stream API 和 `forEach()` 时,这个异常可能是由以下几个常见的原因引起的: 1. **集合本身为空(null)**:如果你尝试将一个 null 的 List 或 Set 转换为 stream 并对其进行迭代,那么这将会导致 NPE。所以在创建流之前应该先检查是否为非空。 2. **流内部含有 null 元素**:即使集合不是 null,但如果其中包含了 null 值并且你在 forEach 内部直接对这些元素进行某些未考虑过的情况下的操作(如调用成员变量、方法等),这也可能会引发 NullPointerException。 3. **外部资源依赖问题**:有时候我们会在 lambda 表达式里面使用来自闭包作用域之外的对象或静态字段。如果有任何一个这样的对象是 null,并且在其上调用了方法或者是进行了其他不允许有 null 值的操作的话,同样会造成 NPE。 为了避免这些问题的发生,可以采取以下措施来保证代码的安全性和健壮性: - 确保传入的 Collection 不为 null,并使用 Optional 类型或者其他机制来进行空值处理。 - 如果允许存在 null 元素,在 foreach 循环体内加入适当的判断逻辑以防止潜在的 NullPointException 异常抛出。 - 尝试简化 Lambda 表达式的复杂度,尽量减少对外围环境变量的依赖;同时也要注意线程安全的问题,尤其是在并发环境下工作的时候。 这里给出一段改进后的样例代码作为示范: ```java import java.util.Arrays; import java.util.List; import java.util.Optional; public class Main { public static void main(String[] args) { // 初始化一个包含可能为 null 元素的列表 List<String> stringList = Arrays.asList("Hello", "World", null, "!"); // 正确的方式: 在转换成 Stream 之后过滤掉所有 null 元素再做后续操作 stringList.stream() .filter(Optional::isPresent) // 注意这里的写法适用于 String 及基本类型包装类 .map(Optional::get) .forEach(System.out::println); // 或者更简单地直接排除 nulls: stringList.stream() .filter(item -> item != null) .forEach(System.out::println); // 错误的做法会触发NullPointerException //stringList.stream().forEach(s -> System.out.println(s.length())); // 这里如果没有前面的 filter() 判断就会报错 } } ``` 上述代码片段展示了两种有效的方式来避免因为 null 导致的运行期错误:一种是在进入 map 操作前利用 filter 来去除所有的 null 元素;另一种则是明确地通过条件表达式 (`item != null`) 排除掉任何可能导致问题的地方。 另外需要注意的是,在实际项目开发过程中,最好养成习惯始终对可能出现 null 地方保持警惕并加以适当防护,无论是显式还是隐式的形式都如此。这样做不仅可以提高应用程序的整体质量,也能大大降低调试成本和维护难度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值