org.mybatis
mybatis
3.5.4
mysql
mysql-connector-java
5.1.47
3、创建对应的数据表
4、创建与表对应的实体类对象
- emp.java
public class Emp {
private Integer id;
private String username;
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;
}
@Override
public String toString() {
return “Emp{” +
“id=” + id +
“, username='” + username + ‘’’ +
‘}’;
}
}
5、创建对应的Mapper接口
- EmpMapper.java
public interface EmpMapper {
// 根据id查询Emp实体
//@Select(“select * from emp where id=#{id}”)
Emp selectEmp(Integer id);
// 插入
Integer insertEmp(Emp emp);
// 更新
Integer updateEmp(Emp emp);
// 删除
Integer deleteEmp(Integer id);
}
6、编写配置文件
- mybatis-config.xml
- EmpMapper.xml
select * from Emp where id = #{id}
INSERT INTO
mybatis
.emp
( username
)
VALUES (#{username});
UPDATE EMP
SET username=#{username}
WHERE id=#{id}
DELETE FROM emp
WHERE id=#{id}
7、编写测试类
- MyTest.java
/***
-
MyBatis 搭建步骤:
-
1.添加pom依赖 (mybatis的核心jar包和数据库版本对应版本的驱动jar包)
-
2.新建数据库和表
-
3.添加mybatis全局配置文件 (可以从官网中复制)
-
4.修改mybatis全局配置文件中的 数据源配置信息
-
5.添加数据库表对应的POJO对象(相当于我们以前的实体类)
-
6.添加对应的PojoMapper.xml (里面就维护所有的sql)
-
修改namespace: 如果是StatementId没有特殊的要求
-
如果是接口绑定的方式必须等于接口的完整限定名
-
修改对应的id(唯一)、resultType 对应返回的类型如果是POJO需要制定完整限定名
-
7.修改mybatis全局配置文件:修改Mapper
*/
public class MybatisTest {
SqlSessionFactory sqlSessionFactory;
@Before
public void before(){
// 从 XML 中构建 SqlSessionFactory
String resource = “mybatis.xml”;
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resource);
} catch (IOException e) {
e.printStackTrace();
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
/**
-
基于StatementId的方式去执行SQL
-
<mapper resource="EmpMapper.xml"/>
-
@throws IOException
*/
@Test
public void test01() {
try (SqlSession session = sqlSessionFactory.openSession()) {
Emp emp = (Emp) session.selectOne(“cn.tulingxueyuan.pojo.EmpMapper.selectEmp”, 1);
System.out.println(emp);
}
}
/**
-
基于接口绑定的方式
-
1.新建数据访问层的接口: POJOMapper
-
2.添加mapper中对应的操作的方法
-
1.方法名要和mapper中对应的操作的节点的id要一致
-
2.返回类型要和mapper中对应的操作的节点的resultType要一致
-
3.mapper中对应的操作的节点的参数必须要在方法的参数中声明
-
3.Mapper.xml 中的namespace必须要和接口的完整限定名要一致
-
4.修改mybatis全局配置文件中的mappers,采用接口绑定的方式:
-
<mapper class="com.mybatis.EmpMapper"></mapper>
-
5.一定要将mapper.xml和接口放在同一级目录中,只需要在resources新建和接口同样结构的文件夹就行了,生成就会合并在一起
-
@throws IOException
*/
@Test
public void test02(){
try (SqlSession session = sqlSessionFactory.openSession()) {
EmpMapper mapper = session.getMapper(EmpMapper.class);
Emp emp = mapper.selectEmp(1);
System.out.println(emp);
}
}
/**
-
基于注解的方式
-
1.在接口方法上面写上对应的注解
*@Select(“select * from emp where id=#{id}”)
-
注意:
-
注解可以和xml共用, 但是不能同时存在方法对应的xml的id
*/
@Test
public void test03(){
try (SqlSession session = sqlSessionFactory.openSession()) {
EmpMapper mapper = session.getMapper(EmpMapper.class);
Emp emp = mapper.selectEmp(1);
System.out.println(emp);
}
}
}
4、增删改查的基本操作
- EmpMapper.java
public interface EmpMapper {
public Emp findEmpByEmpno(Integer empno);
public int updateEmp(Emp emp);
public int deleteEmp(Integer empno);
public int insertEmp(Emp emp);
}
- EmpMapper.xml
select * from emp where empno = #{empno}
insert into emp(empno,ename) values(#{empno},#{ename})
update emp set ename=#{ename} where empno = #{empno}
delete from emp where empno = #{empno}
- MyTest.java
public class MyTest {
SqlSessionFactory sqlSessionFactory = null;
@Before
public void init(){
// 根据全局配置文件创建出SqlSessionFactory
// SqlSessionFactory:负责创建SqlSession对象的工厂
// SqlSession:表示跟数据库建议的一次会话
String resource = “mybatis-config.xml”;
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
@Test
public void test01() {
// 获取数据库的会话
SqlSession sqlSession = sqlSessionFactory.openSession();
Emp empByEmpno = null;
try {
// 获取要调用的接口类
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
// 调用方法开始执行
empByEmpno = mapper.findEmpByEmpno(7369);
} catch (Exception e) {
e.printStackTrace();
} finally {
sqlSession.close();
}
System.out.println(empByEmpno);
}
@Test
public void test02(){
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
int zhangsan = mapper.insertEmp(new Emp(1111, “zhangsan”));
System.out.println(zhangsan);
sqlSession.commit();
sqlSession.close();
}
@Test
public void test03(){
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
int zhangsan = mapper.updateEmp(new Emp(1111, “lisi”));
System.out.println(zhangsan);
sqlSession.commit();
sqlSession.close();
}
@Test
public void test04(){
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
int zhangsan = mapper.deleteEmp(1111);
System.out.println(zhangsan);
sqlSession.commit();
sqlSession.close();
}
}
- EmpMapperImpl.java
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://i-blog.csdnimg.cn/blog_migrate/a9e69743ec35a26e89057c960e10e7ee.jpeg)
最后,附一张自己面试前准备的脑图:
面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典
- Java核心知识整理
- Spring全家桶(实战系列)
Step3:刷题
既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。
以下是我私藏的面试题库:
很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。
最后祝愿各位身体健康,顺利拿到心仪的offer!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
14a7895254671a72faed303032d36.jpg" alt=“img” style=“zoom: 33%;” />
最后,附一张自己面试前准备的脑图:
[外链图片转存中…(img-CQQyzL1K-1713528665667)]
面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典
- Java核心知识整理
[外链图片转存中…(img-t8Fqr0NB-1713528665667)]
- Spring全家桶(实战系列)
[外链图片转存中…(img-Z4M3Hh1u-1713528665667)]
Step3:刷题
既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。
以下是我私藏的面试题库:
[外链图片转存中…(img-1NIkPBIZ-1713528665668)]
很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。
最后祝愿各位身体健康,顺利拿到心仪的offer!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!