第三步、编写User.java中的内容,如下所示:
package cn.itcast.mybatis.po;
import java.util.Date;
/**
-
Title: User
-
Description:用户po
-
@author 丁国华
-
@date 2016年7月31日 15:39:04
-
@version 1.0
*/
public class User {
//属性名和数据库表的字段对应
private int id;
private String username;// 用户姓名
private String sex;// 性别
private Date birthday;// 生日
private String address;// 地址
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return “User [id=” + id + “, username=” + username + “, sex=” + sex
- “, birthday=” + birthday + “, address=” + address + “]”;
}
}
第四步、实现增删改查的功能,首先编写User.xml中的内容,如下所示:
<?xml version="1.0" encoding="UTF-8" ?>
SELECT * FROM USER WHERE id=#{value}
SELECT * FROM USER WHERE username LIKE ‘%${value}%’
SELECT LAST_INSER_ID()
insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address})
SELECT uuid()
insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address});
delete from user where id=#{id}
update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address}
where id=#{id}
第五步、编写具体的方法,如下所示:
package cn.itcast.mybatis.first;
import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
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 org.junit.Test;
import cn.itcast.mybatis.po.User;
public class MybatisFirst {
// 根据id查询用户信息,得到一条记录结果
@Test
public void findUserByIdTest() throws IOException {
// mybatis配置文件
String resource = “SqlMapConfig.xml”;
// 得到配置文件流
InputStream inputStream = Resources.getResourceAsStream(resource);
// 创建会话工厂,传入mybatis的配置文件信息
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
.build(inputStream);
// 通过工厂得到SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
// 通过SqlSession操作数据库
// 第一个参数:映射文件中statement的id,等于=namespace+“.”+statement的id
// 第二个参数:指定和映射文件中所匹配的parameterType类型的参数
// sqlSession.selectOne结果 是与映射文件中所匹配的resultType类型的对象
// selectOne查询出一条记录
User user = sqlSession.selectOne(“test.findUserById”, 1);
System.out.println(user);
// 释放资源
sqlSession.close();
}
//根据用户名称模糊查询用户列表
@Test
public void findUserByNameTest() throws IOException{
//mybatis配置文件
String resource =“SqlMapConfig.xml”;
//得到配置文件
InputStream inputStream = Resources.getResourceAsStream(resource);
//创建会话工厂,传入mybatis的配置文件信息
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//通过工厂得到SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
//List中的user和映射文件中德resultType所指定的类型一致
List list = sqlSession.selectList(“test.findUserByName”,“小明”);
System.out.println(list);
sqlSession.close();
}
public void insertUserTest() throws IOException{
//mybatis配置文件
String resource =“SqlMapConfig”;
//得到配置文件流
InputStream inputStream = Resources.getResourceAsStream(resource);
//创建会话工厂,传入mybatis的配置文件信息
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//通过工厂得到sqlsession
SqlSession sqlSession = sqlSessionFactory.openSession();
//插入用户对象
User user = new User();
user.setUsername(“丁国华”);
user.setBirthday(new Date());
user.setSex(“1”);
user.setAddress(“安徽合肥”);
//list中的user和映射文件中的resultType所指定的类型一直
sqlSession.insert(“test.insertUser”,user);
//提交事物
sqlSession.commit();
//关闭会话
sqlSession.close();
}
//根据id删除用户信息
@Test
public void deleteUserTest() throws IOException{
最后
整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣,
;
//提交事物
sqlSession.commit();
//关闭会话
sqlSession.close();
}
//根据id删除用户信息
@Test
public void deleteUserTest() throws IOException{
最后
整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。
[外链图片转存中…(img-58HbJxZ5-1714419664224)]
[外链图片转存中…(img-GqtbtCpB-1714419664224)]
其实面试这一块早在第一个说的25大面试专题就全都有的。以上提及的这些全部的面试+学习的各种笔记资料,我这差不多来回搞了三个多月,收集整理真的很不容易,其中还有很多自己的一些知识总结。正是因为很麻烦,所以对以上这些学习复习资料感兴趣,