Mybatis循环插入报数据库连接超过最大数

今天用mybatis循环插入数据的时候,插到一百条左右的时候,突然报错,意思就是mysql连接数已经达到最大数。
我看到就想应该是插入一条数据的时候没有释放连接,就百度怎么释放连接,回答说是mybatis能自动释放连接,但是在高并发也会出现这种结果,但是明显这种问题不是高并发。
后来发现我在SqlSessionFactory实例化太多了,导致报错,改成只实例化一个就好了,这个问题我感觉可能初学者会犯,记录一下


之前的错误代码

private SqlSessionFactory factory;

public static void setUp() throws Exception{
    String resource = "SqlMapConfig.xml";
    //通过流将核心配置文件读取进来
    InputStream inputStream = Resources.getResourceAsStream(resource);
    //通过核心配置文件输入流来创建会话工厂
    factory = new SqlSessionFactoryBuilder().build(inputStream);
}

public void testFindUserById() throws Exception{
    setUp();
    SqlSession openSession = factory.openSession();
    ///通过getMapper方法来实例化接口
    UserMapper mapper = openSession.getMapper(UserMapper.class);

    User user = mapper.findUserById(1);
    System.out.println(user);
}

改正之后

private SqlSessionFactory factory;

static {
    String resource = "SqlMapConfig.xml";
    //通过流将核心配置文件读取进来
    InputStream inputStream;
    try {
        inputStream = Resources.getResourceAsStream(resource);
        //通过核心配置文件输入流来创建会话工厂
        factory = new SqlSessionFactoryBuilder().build(inputStream);
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}

public void findUserById(int id) throws Exception{
    SqlSession openSession = factory.openSession();
    ///通过getMapper方法来实例化接口
    UserMapper mapper = openSession.getMapper(UserMapper.class);

    User user = mapper.findUserById(id);
    openSession.commit();
    openSession.close();
    System.out.println(user);
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值