一. 使用Mybatis需要jar包:
mybatis.jar , 同时连接数据库需要 mysql-connection.jar
二. 开始Demo
2.1 在数据库新建表Users,插入数据
2.2 新建web项目,建包
2.2.1 首先新建POJO类,属性与数据库中的表字段一致。
2.2.2 新建该项目的配置文件conf.xml(在src下),在该配置文件中可以配置连接数据库,可以引用Mapper.xml文件。
<?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="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/mybatis" /> <property name="username" value="root" /> <property name="password" value="123,456a" /> </dataSource> </environment> </environments> <mappers> <mapper resource="com/imut/mapping/userMapper.xml"/> </mappers> </configuration> 2.2.3 新建该项目中对应POJO类的Mapper.xml文件,该文件中的操作主要是对POJO类的操作。 <?xml version="1.0" encoding="utf-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- 为这个mapper指定一个唯一的namespace,namespace的值习惯上设置成Mapper的全名。 例如namespace="com.imut.mapping.userMapper"就是操作com.imut.po.User的文件--> <mapper namespace="com.imut.mapping.userMapper" > <select id="getUserById" parameterType="int" resultType="com.imut.po.User"> select * from users where id = #{id} </select> </mapper>2.3.4 使用这些文件,显示查询结果 public class SelectUserByIdTest { /** * @param args */ public static void main(String[] args) { String resource = "conf.xml";//mybatis的配置文件 InputStream is = SelectUserByIdTest.class.getClassLoader().getResourceAsStream(resource);//使用类加载器加载mybatis的配置文件(它的加载关联的映射文件) SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);//构建sqlSession的工厂 SqlSession sqlSession = sessionFactory.openSession();//创建SqlSession //映射sql的标识字符串 String statement = "com.imut.mapping.userMapper.getUserById"; User user = sqlSession.selectOne(statement,1); System.out.println("result <---->"+user); } } 结果: result <---->User -->1 -->name -->zhangsan--> age -->-->22