SSM项目之商铺系统-DAO层之新增店铺和更新店铺(五)

2024-02-18 02:32

本文主要是介绍SSM项目之商铺系统-DAO层之新增店铺和更新店铺(五),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

新增店铺:

第一步:建立DAO层接口并且实现新增店铺功能的接口

 

第二步:建立ShopDao的xml映射文件并且实现了相应的功能

 

    <!--useGeneratedKeys开启了返回自增主键 的值,这样直接将表中主键值存入了相应的实体类中的属性keyColumn指定数据表中主键的列名keyProperty指定实体类中对应主键的属性名--><insert id="insertShop" useGeneratedKeys="true" keyColumn="shop_id" keyProperty="shopId">INSERT INTOtb_shop(owner_id,area_id,shop_category_id,shop_name,shop_desc,shop_addr,phone,shop_img,priority,create_time,last_edit_time,enable_status,advice)VALUES (#{owner.userId},#{area.areaId},#{shopCategory.shopCategoryId},#{shopName},#{shopDesc},#{shopAddr},#{phone},#{shopImg},#{priority},#{createTime},#{lastEditTime},#{enableStatus},#{advice})</insert>

 我们插入了一个商铺的所有信息

接下来完成测试:

public class ShopDaoTest extends BaseTest {@Autowiredprivate ShopDao shopDao;@Testpublic void testInsertShop(){Shop shop=new Shop();PersonInfo personInfo=new PersonInfo();ShopCategory shopCategory=new ShopCategory();Area area =new Area();personInfo.setUserId(1L);//long型后面加LshopCategory.setShopCategoryId(1L);area.setAreaId(2);shop.setOwner(personInfo);shop.setArea(area);shop.setShopName("测试的店铺");shop.setShopCategory(shopCategory);shop.setShopAddr("test");shop.setPhone("test");shop.setShopDesc("test");shop.setShopImg("test");shop.setCreateTime(new Date());shop.setAdvice("审核中");shop.setEnableStatus(1);int effect =shopDao.insertShop(shop);Assert.assertEquals(1,effect);}

测试思路:

我们新建一个shop实体类,手动装配所有shop的信息,通过shopDao的接口实现类(这里用的接口因为我们用autowired装配害会,他会自己装配实现类)的插入方法插入这个shop,我们查看通过返回值(操作影响的行数)判断是否成功插入。

 

更新店铺 :

第一步:建立DAO层接口并建立相应的方法

第二步:配置相应的mapper配置文件

思路:

我们用到了动态sql语句,因为我们每次更新并不是更新每条记录,所以我们判断每个传入的属性是否为空,为空则不需要更新,不为空我们则需要更新,注意:最后一个<if />语句不需要“,”。最后限定条件为shop_id。

测试:

第一步建立相应的test类

测试代码:

public class ShopDaoTest extends BaseTest {@Autowiredprivate ShopDao shopDao; 
@Testpublic void testUpdateShop(){Shop shop=new Shop();shop.setShopId(6L);shop.setShopName("测试更新的店铺");shop.setShopAddr("test更新");shop.setPhone("test更新");shop.setShopDesc("test更新");shop.setShopImg("test更新");shop.setLastEditTime(new Date());shop.setAdvice("test更新审核中");int effect =shopDao.updateShop(shop);Assert.assertEquals(1,effect);}
}

测试思路

自己建立一个shop实例并且完成相应的属性赋值,通过shopDao的接口的方法返回值(操作的行数)判断是否完成修改。

这篇关于SSM项目之商铺系统-DAO层之新增店铺和更新店铺(五)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/719768

相关文章

springboot项目中使用JOSN解析库的方法

《springboot项目中使用JOSN解析库的方法》JSON,全程是JavaScriptObjectNotation,是一种轻量级的数据交换格式,本文给大家介绍springboot项目中使用JOSN... 目录一、jsON解析简介二、Spring Boot项目中使用JSON解析1、pom.XML文件引入依

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实