单一使用Mybatis, SqlSession 注意项
发布时间:2020-12-14 05:10:01 所属栏目:百科 来源:网络整理
导读:###这是读取mybatis配置得到SqlSessionFactory的代码块 public static org.apache.ibatis.session.SqlSessionFactory sqlSessionFactory; static { String resource = "mybatis-config.xml"; InputStream inputStream = null; try { inputStream = Resources
###这是读取mybatis配置得到SqlSessionFactory的代码块 public static org.apache.ibatis.session.SqlSessionFactory sqlSessionFactory; static { String resource = "mybatis-config.xml"; InputStream inputStream = null; try { inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); com.map.mapper.SqlSessionFactory.sqlSessionFactory.getConfiguration().addMapper(Map.class); } catch (IOException e) { e.printStackTrace(); } } 这是从sqlSessionFactory 里取一个SqlSession出来保持对数据库的连接。但是这里需要特别注意的一点是在完成数据库操作后 一定要执行 session.close(); 关闭对数据库的连接。public List<HotSpot> getHotSpot(int merchat_id) { SqlSession session = com.map.mapper.SqlSessionFactory.sqlSessionFactory.openSession(); Map map = session.getMapper(Map.class); List<HotSpot> hotSpot = map.getHotSpot(merchat_id); session.close(); return hotSpot; } 如果不连接会导致一个怎样的后果呢?比如下面一段代码(mapService调用的底层方法都是依赖SqlSession对数据库的操作)会导致大量的无效连接占用着数据库的连接资源,整个程序会hang住,让人感觉以为是程序的死循环,其实是 SqlSession 没有关闭导致了大量的连接一直耗费着数据库的资源而hang住了。所以我们写代码一定要注意下。for (Merchant chat : list_merchat) { List<HotSpot> list_hotSpot = mapService.getHotSpot(chat.getMerchat_id()); for (HotSpot hotspot : list_hotSpot) { Coordinate coordinate = mapService.getCoordinate(hotspot.getCoordinate_id()); hotspot.setHotspot_coord(coordinate); } chat.setHotspots(list_hotSpot); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |