单一使用Mybatis, SqlSession 注意项

这是读取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);
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值