首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

springboot学习-整合mybatis实现数据的持久化

之前我们分别使用了spring-data-jpa和jdbcTemplate实现对数据的增删改查,这一篇我们使用更加常用的方法实现数据的持久化,整合mybatis。

我们依然通过做一个实例来学习,始终相信先看着做出来,再加强理论,搞清原理的学习方法比较快。

下图是项目整体结构:

新建一个MySQL数据库,这里数据库名为springboot,建立user_t数据表,作为我们示例操作的表对象。

user_t信息如下:

数据库及表创建成功后,回到我们的工程中

第零步,我们这里集成druid,使用连接池,引入mybatis及druid的依赖包:

第一步,在yml配置文件中配置数据源、Mybatis的实体和配置文件路径:

第二步,创建一个实体类,对应数据表实体映射:

第三步,写DAO接口(增删改查):

第四步,编写xml映射文件:

第五步,编写Service接口:

第六步,Service接口的实现类:

第七步,新建一个Controller类,实现增删改查操作接口:

最后,我们修改Bootdemo03Application启动类,添加@MapperScan注解,使其可以扫描DAO层接口:

这样,我们就实现了springboot整合mybatis完成对数据简单的增删改查的demo,我们测试一下所写的程序是否可以正常工作。

查询测试:

新增测试:

修改测试:

删除测试:

我们可以看到可以全部测试通过。

几个问题:

1、@Resource注解的理解?

@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了。@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。

@Resource装配顺序

如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常

如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常

如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常

如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

2、@Autowired 与@Resource的区别:

@Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。

@Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false) 。

@Resource,默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。

关注后端技术精选,提供优质价值阅读

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180718G1C1BA00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券