因为它是一个非线程安全的对象。每个SQLSession对象都维护了一个独立的数据库连接,以及与该连接相关的事务和缓存。如果多个线程共享同一个SQLSession对象,可能会导致数据混乱、事务冲突等问题。另外,SQLSession对象还包含了一级缓存,用于缓存查询结果和映射对象。如果多个线程共享同一个SQLSession对象,可能会导致缓存数据的不一致。为了确保数据的一致性和线程安全,通常会将SQLSession对象的生命周期限定在一个线程内部,即每个线程都创建自己的SQLSession对象,并在使用完毕后及时关闭。这样可以避免多个线程之间的竞争和干扰,保证数据的正确性和完整性。