创建数据库
create database mybatis_demo; use mybatis_demo; CREATE TABLE `user` ( `id` int(11) NOT NULL auto_increment, `username` varchar(32) NOT NULL COMMENT '用户名称', `birthday` datetime default NULL COMMENT '生日', `sex` char(1) default NULL COMMENT '性别', `address` varchar(256) default NULL COMMENT '地址', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; insert into `user`(`id`,`username`,`birthday`,`sex`,`address`) values (1,'老王','2018-02-27 17:47:08','男','北京'), (2,'熊大','2018-03-02 15:09:37','女','上海'), (3,'熊二','2018-03-04 11:34:34','女','深圳'), (4,'光头强','2018-03-04 12:04:06','男','广州');
配置数据库驱动
在src\main\resources目录下创建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"> <configuration> <environments default="mysql"> <environment id="mysql"> <!--配置事务的类型,使用本地事务策略--> <transactionManager type="JDBC"></transactionManager> <!--是否使用连接池 POOLED表示使用链接池,UNPOOLED表示不使用连接池--> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis_demo"/> <property name="username" value="root"/><!--用户--> <property name="password" value="20220101"/><!--密码--> </dataSource> </environment> </environments> <mappers> </mappers> </configuration>
增删改查
查询
<select id="" resultType=""></select>
- id是唯一标识符,整个.xml中只能有一个,不同的标签设定不同的id。
- resultType查询结果集类型,一般是类对象。
创建类。在src\main\java目录下创建com.qcby.entity包(包名随便起),在该包下创建类User(一般与数据表的表名相同),定义私有属性(要与数据表中的字段名相同),get和set方法以及toString方法。具有上述特性的类叫做JavaBean。
public class User { private Integer id; private String username; private Date birthday; 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 getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } 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 + '\'' + ", birthday=" + birthday + ", sex='" + sex + '\'' + ", address='" + address + '\'' + '}'; } }
创建接口。在src\main\java目录下创建com.qcby.dao包(包名随便起),在该包下创建接口UserDao(一般与数据表的表名+Dao)。
public interface UserDao { }
创建.xml。在src\main\resources目录下创建mapper文件夹,在该文件夹下创建UserMapper.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.qcby.dao.UserDao"> <select id="findAll" resultType="com.qcby.entity.User"> select * from user <!--SQL语句--> </select> </mapper>
namespace=""里面写接口路径(包名.接口名) id=""里面是该select的唯一标识符 resultType=""里面是数据结果集的路径(包名.类)
把下段代码放到SqlMapConfig.xml文件的mappers标签里面
<mapper resource="mapper/UserMapper.xml"></mapper> <!--resource=""里面是UserMapper.xml文件的路径-->
在接口中创建新方法,方法名与.xml中select标签的id名相同(必须)
public interface UserDao { // 查询所有用户 public List<User> findAll(); }
创建测试类。在src\test\java目录下创建UserTest类
public class UserTest { private InputStream in = null; private SqlSession session = null; private UserDao mapper = null;//UserDao必须与接口名一致 @Before //前置通知, 在方法执行之前执行 public void init() throws IOException { //加载主配置文件,目的是为了构建SqlSessionFactory对象 in = Resources.getResourceAsStream("SqlMapConfig.xml"); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory工厂对象创建SqlSesssion对象 session = factory.openSession(); //通过Session创建UserDao接口代理对象 mapper = session.getMapper(UserDao.class);//UserDao必须与接口名一致 } @After //@After: 后置通知, 在方法执行之后执行 。 public void destory() throws IOException { //释放资源 session.close(); in.close(); } //测试查询所有的方法 @Test public void findAll() throws IOException { List<User> users = mapper.findAll(); for (User user:users) { System.out.println(user.toString()); } } }
插入
<insert id="" parameterType=""></insert>
- id是唯一标识符,整个.xml中只能有一个,不同的标签设定不同的id。
- parameterType入参类型。
使用已创建的User类,UserDao接口,.xml文件。在.xml文件里编写以下内容
<insert id="insert" parameterType="com.qcby.entity.User"> insert into user(username,birthday,sex,address) values(#{username},#{birthday},#{sex},#{address}); </insert>
- 在接口中创建新方法,方法名必须与上面的id名一致
public interface UserDao { //插入数据 public int insert(User user); }
- 编写测试类
public class UserTest { private InputStream in = null; private SqlSession session = null; private UserDao mapper = null; @Before //前置通知, 在方法执行之前执行 public void init() throws IOException { //加载主配置文件,目的是为了构建SqlSessionFactory对象 in = Resources.getResourceAsStream("SqlMapConfig.xml"); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory工厂对象创建SqlSesssion对象 session = factory.openSession(); //通过Session创建UserDao接口代理对象 mapper = session.getMapper(UserDao.class); } @After //@After: 后置通知, 在方法执行之后执行 。 public void destory() throws IOException { //释放资源 session.close(); in.close(); } //插入 @Test public void insert(){ User user=new User(); user.setUsername("AGi"); user.setBirthday(new Date()); user.setSex("男"); user.setAddress("保定"); int flag=mapper.insert(user); session.commit(); System.out.println(user.getId()); } }
修改
<update id="" parameterType=""></update>
- id是唯一标识符,整个.xml中只能有一个,不同的标签设定不同的id。
- parameterType入参类型。
使用已创建的User类,UserDao接口,.xml文件。在.xml文件里编写以下内容
<update id="update" parameterType="com.qcby.entity.User"> update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address} where id=#{id} </update>
- 在接口中创建新方法,方法名必须与上面的id名一致
public interface UserDao { //修改数据 public int update(User user); }
- 编写测试类
public class UserTest { private InputStream in = null; private SqlSession session = null; private UserDao mapper = null; @Before //前置通知, 在方法执行之前执行 public void init() throws IOException { //加载主配置文件,目的是为了构建SqlSessionFactory对象 in = Resources.getResourceAsStream("SqlMapConfig.xml"); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory工厂对象创建SqlSesssion对象 session = factory.openSession(); //通过Session创建UserDao接口代理对象 mapper = session.getMapper(UserDao.class); } @After //@After: 后置通知, 在方法执行之后执行 。 public void destory() throws IOException { //释放资源 session.close(); in.close(); } //修改 @Test public void update(){ User user=new User(); user.setUsername("AGi"); user.setBirthday(new Date()); user.setSex("男"); user.setAddress("保定"); user.setId(1); int flag= mapper.update(user); session.commit(); System.out.println(flag); } }
删除
<delete id="" parameterType=""></delete>
- id是唯一标识符,整个.xml中只能有一个,不同的标签设定不同的id。
- parameterType入参类型。
- 使用已创建的User类,UserDao接口,.xml文件。
- 在.xml文件里编写以下内容
</update> <delete id="delete" parameterType="java.lang.Integer"> delete from user where id=#{value} </delete>
- 在接口中创建新方法,方法名必须与上面的id名一致
public interface UserDao { //删除 public int delete(Integer id); }
- 编写测试类
public class UserTest { private InputStream in = null; private SqlSession session = null; private UserDao mapper = null; @Before //前置通知, 在方法执行之前执行 public void init() throws IOException { //加载主配置文件,目的是为了构建SqlSessionFactory对象 in = Resources.getResourceAsStream("SqlMapConfig.xml"); //创建SqlSessionFactory对象 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //通过SqlSessionFactory工厂对象创建SqlSesssion对象 session = factory.openSession(); //通过Session创建UserDao接口代理对象 mapper = session.getMapper(UserDao.class); } @After //@After: 后置通知, 在方法执行之后执行 。 public void destory() throws IOException { //释放资源 session.close(); in.close(); } //删除 @Test public void delete(){ int flag= mapper.delete(3); session.commit(); System.out.println(flag); } }