BAEL-788 Added java config (#1660)
* BAEL-788 Added java config * BAEL-788 Removed XML config
This commit is contained in:
parent
c313256e8e
commit
76409e6d53
|
@ -1,24 +1,39 @@
|
||||||
package com.baeldung.mybatis.utils;
|
package com.baeldung.mybatis.utils;
|
||||||
|
|
||||||
|
import com.baeldung.mybatis.mapper.AddressMapper;
|
||||||
|
import com.baeldung.mybatis.mapper.PersonMapper;
|
||||||
|
import org.apache.ibatis.datasource.pooled.PooledDataSource;
|
||||||
import org.apache.ibatis.io.Resources;
|
import org.apache.ibatis.io.Resources;
|
||||||
import org.apache.ibatis.jdbc.SQL;
|
import org.apache.ibatis.jdbc.SQL;
|
||||||
|
import org.apache.ibatis.mapping.Environment;
|
||||||
|
import org.apache.ibatis.session.Configuration;
|
||||||
import org.apache.ibatis.session.SqlSessionFactory;
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
|
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
|
||||||
|
import org.apache.ibatis.transaction.jdbc.JdbcTransactionFactory;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
public class MyBatisUtil {
|
public class MyBatisUtil {
|
||||||
|
public static final String DRIVER = "org.apache.derby.jdbc.EmbeddedDriver";
|
||||||
|
public static final String URL = "jdbc:derby:testdb1;create=true";
|
||||||
|
public static final String USERNAME = "sa";
|
||||||
|
public static final String PASSWORD = "pass123";
|
||||||
private static SqlSessionFactory sqlSessionFactory;
|
private static SqlSessionFactory sqlSessionFactory;
|
||||||
static {
|
|
||||||
String resource = "mybatis-config.xml";
|
public static SqlSessionFactory buildqlSessionFactory(){
|
||||||
InputStream inputStream;
|
DataSource dataSource=new PooledDataSource(DRIVER, URL, USERNAME, PASSWORD);
|
||||||
try {
|
Environment environment=new Environment("Development",new JdbcTransactionFactory(),dataSource);
|
||||||
inputStream = Resources.getResourceAsStream(resource);
|
Configuration configuration = new Configuration(environment);
|
||||||
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
|
configuration.addMapper(PersonMapper.class);
|
||||||
} catch (IOException e) {
|
configuration.addMapper(AddressMapper.class);
|
||||||
e.printStackTrace();
|
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
|
||||||
}
|
SqlSessionFactory factory = builder.build(configuration);
|
||||||
|
return factory;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SqlSessionFactory getSqlSessionFactory(){
|
public static SqlSessionFactory getSqlSessionFactory(){
|
||||||
return sqlSessionFactory;
|
return sqlSessionFactory;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
|
||||||
<!DOCTYPE configuration
|
|
||||||
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
|
|
||||||
"http://mybatis.org/dtd/mybatis-3-config.dtd">
|
|
||||||
<configuration>
|
|
||||||
<environments default="development">
|
|
||||||
<environment id="development">
|
|
||||||
<transactionManager type="JDBC"/>
|
|
||||||
<dataSource type="POOLED">
|
|
||||||
<property name="driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
|
|
||||||
<property name="url" value="jdbc:derby:testdb1;create=true"/>
|
|
||||||
<property name="username" value="sa"/>
|
|
||||||
<property name="password" value="pass123"/>
|
|
||||||
</dataSource>
|
|
||||||
</environment>
|
|
||||||
</environments>
|
|
||||||
<mappers>
|
|
||||||
<mapper class="com.baeldung.mybatis.mapper.PersonMapper"/>
|
|
||||||
<mapper class="com.baeldung.mybatis.mapper.AddressMapper"/>
|
|
||||||
</mappers>
|
|
||||||
</configuration>
|
|
|
@ -23,7 +23,7 @@ public class PersonMapperTest {
|
||||||
@Before
|
@Before
|
||||||
public void setup() throws SQLException {
|
public void setup() throws SQLException {
|
||||||
|
|
||||||
session = MyBatisUtil.getSqlSessionFactory().openSession();
|
session = MyBatisUtil.buildqlSessionFactory().openSession();
|
||||||
createTables(session);
|
createTables(session);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue