文章目录
环境搭建
maven配置jar包
在pom.xml添加如下内容
<dependencies> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.7</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.14.1</version> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-api</artifactId> <version>5.7.0</version> <scope>test</scope> </dependency> </dependencies>
创建实体类和接口 及序列化
实体类User如下 需要继承序列化接口
关于序列化(implements Serializable):
https://www.cnblogs.com/xie-qi/p/12915866.html
package com.xiongshou.domain; import java.io.Serializable; import java.util.Date; public class User implements Serializable {//序列化 private Integer id; private String username; private Date brithday; private String sex; private String address; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public Date getBrithday() { return brithday; } public void setBrithday(Date brithday) { this.brithday = brithday; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", brithday=" + brithday + ", sex='" + sex + '\'' + ", address='" + address + '\'' + '}'; } }
创建IUserDao接口定义查询表中全部内容函数FindAll
package com.xiongshou.dao; import com.xiongshou.domain.User; import java.util.List; public interface IUserDao { /** * 查询表中所有 * @return */ List<User> FindAll(); }
创建主配置文件
在资源库创建 SqlMapConfig.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"> <!--mybatis主配置文件--> <configuration> <!-- 配置环境 --> <environments default="mysql"> <!--配置mysql环境--> <environment id="mysql"> <!--配置事务--> <transactionManager type="JDBC"></transactionManager> <!--配置数据源(连接池)--> <dataSource type="POOLED"> <property name="driver" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/> <property name="username" value="root"/> <property name="password" value="adminadmin"/> </dataSource> </environment> </environments> <!--指定映射配置文件,即每个dao独立的配置文件--> <mappers> <mapper resource="com/xiongshou/dao/IUserDao.xml"/> </mappers> </configuration>
创建映射配置文件
创建映射配置文件 IUserDao.xml
<?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="com.xiongshou.dao.IUserDao"> <!--配置查询所有 id为方法名称--> <select id="FindAll" resultType="com.xiongshou.domain.User"> select * from user; </select> </mapper>
注意事项
1.创建IUserDao.xml和IUserDao.java中的dao是为了和之前的知识保持联系,在mybatis中 持久层接口名称和映射文件叫:Mapper
所有IUserDao和IUserMapper是一样的
2.mybatis的映射文件位置必须和dao接口的包结构1保持相同
3.映射配置文件 mapper 标签 namespace属性必须是全类名
4映射配置文件的操作配置 (select)id属性必须是dao接口的方法名
当遵从了2,3,4条之后就无需再写dao类的实现,只需要写接口即可
mybatis入门案例
xml配置使用mybatis
使用之前的环境 创建main输入以下代码即可
package com.xionghsou.test; import com.xiongshou.dao.IUserDao; import com.xiongshou.domain.User; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException; import java.io.InputStream; import java.util.List; /** * 入门案例 */ public class MybatisTest { public static void main(String[] args) throws IOException { //1.读取配置文件 InputStream in= Resources.getResourceAsStream("SqlMapConfig.xml"); //2.创建SqlsessionFactory工厂 SqlSessionFactoryBuilder builder=new SqlSessionFactoryBuilder(); SqlSessionFactory factory=builder.build(in); //3.使用工厂生产Sqlsession对象 SqlSession session=factory.openSession(); //4。使用Sqlsession创建dao接口的代理对象 IUserDao userDao=session.getMapper(IUserDao.class); //5.使用代理对象执行方法 List<User> list=userDao.FindAll(); for (User i: list) { System.out.println(i); } //6.释放资源 session.close(); in.close(); } }
执行便可以获取user表中所有数据
使用注解的方式使用mybatis
删除映射配置文件 IUserDao.xml
同时更改SqlMapConfig.xml为:
<!--指定映射配置文件,即每个dao独立的配置文件--> <mappers> <mapper class="com.xiongshou.dao.IUserDao"/> </mappers>
在IuserDao.java中在函数上方添加注解@Select(“select * from user”)
再次运行test即可
分析
入门案例分析
findall 分析
自定义mybatis分析
补充
Java代理 proxy
https://www.cnblogs.com/xdp-gacl/p/3971367.html