这篇文章我们重点介绍Service层。因为Dao层就是用Gysypml逆向生成的Mapper就可以了。所以这里重点讲解Service层。

业务逻辑如下:

1:我们从前端页面传入有两个值:1:usergysid(供应商的id),2:YPPxxID(药品的目录id)

我们看一下我们要插入数据的表:

我们要做的就是把这两个字段插入。

2:我们看这样表的设计:

这里有这么一个约束,那就是YPXXID和USERGYSID两个字段成为一个主键。

我们在Service层应该做的步骤如下:

1:我们根据传入的usergysid(供应商id)和药品id去供应商药品表中去查找记录,有查到记录那就抛出异常。

2:然后根据药品id去药品表中查找此药品,能找到就是没问题,如果没找到那就抛异常。

3:往Gysypml表里面插入数据。

4:我们验证完了供应商药品表,我们还要验证供应商药品目录控制表。

(1):根据传入的usergysid和药品id去查找供应商药品目录控制表中有没有已经存在的记录。

有那就抛异常,没有就ok.

具体代码如下:

    /**
*
* @author Sxq
* @Title: findGysymplByGysyisAndYpxxid
* @Description: 在Gysymld查找记录
* @param @param usergysid
* @param @param ypxxid
* @param @return
* @return Gysypml
* @throws
*/
public Gysypml findGysymplByGysyisAndYpxxid(String usergysid, String ypxxid) {
GysypmlExample gysypmlExample = new GysypmlExample();
GysypmlExample.Criteria criteria = gysypmlExample.createCriteria();
criteria.andUsergysidEqualTo(usergysid);
criteria.andYpxxidEqualTo(ypxxid); List<Gysypml> gysypmllist = gysypmlMapper
.selectByExample(gysypmlExample);
if (gysypmllist.size() == 1) { return gysypmllist.get(0);
} else {
return null;
} } // 在GysypmlControl表中查找GysypmlControl public GysypmlControl findGysypmlControlByGysyisAndYpxxid(String usergysid,
String ypxxid) { GysypmlControlExample gysypmlControlExample = new GysypmlControlExample();
GysypmlControlExample.Criteria criteria = gysypmlControlExample
.createCriteria();
criteria.andUsergysidEqualTo(usergysid);
criteria.andYpxxidEqualTo(ypxxid); List<GysypmlControl> gysypmlControls = gysypmlControlMapper
.selectByExample(gysypmlControlExample);
if (gysypmlControls.size() == 1) { return gysypmlControls.get(0);
} else {
return null;
} } /**
*
* @author Sxq
* @Title: insertGysympl
* @Description: 往供应商药品目录表中和供应商药品目录控制表插入数据
* @param @param usergysid
* @param @param ypxxid
* @param @throws Exception
* @return void
* @throws
*/
@Override
public void insertGysympl(String usergysid, String ypxxid) throws Exception { // 供应商药品目录表的验证(Gysypml表)
// 根据传进来的usergysid和ypxxid去Gysypml表去查询有没有这条数据,因为供货商目录表只能添加之前不存在的数据
// 已经存在在表里的数据是不能被插入了,这样会违反主键约束,
Gysypml gysypml = this.findGysymplByGysyisAndYpxxid(usergysid, ypxxid);
if (gysypml != null)// 如果查出来为空,说明实现已经存在这条数据了,那么我们就要抛异常了。
{
ResultUtil.throwExcepion(ResultUtil.createFail(Config.MESSAGE, 41,
null)); }
// 查找这个药品
Ypxx ypxx = ypxxMapper.selectByPrimaryKey(ypxxid);
if (ypxx == null) {
ResultUtil.throwExcepion(ResultUtil.createFail(Config.MESSAGE, 41,
null)); }
// 药品交易状态的验证
String jyzt = ypxx.getJyzt();
if (jyzt.equals("2")) {
// 药品状态为暂停不允许添加
ResultUtil.throwExcepion(ResultUtil.createFail(Config.MESSAGE, 403,
new Object[] { ypxx.getBm(), ypxx.getMc() })); } // 如果前面的验证都通过了那么进行插入数据,我们之前提过插入数据的其实向两张表插入式数据
// 一张是药品管理目录表,一张是药品目录控制表
Gysypml gysypml2 = new Gysypml();
gysypml2.setId(UUIDBuild.getUUID());// 设置主键
gysypml2.setUsergysid(usergysid);
gysypml2.setId(ypxxid);
gysypmlMapper.insert(gysypml2);// 把数据插入到药品管理目录表 // 药品控制表(GysypmlControl表)的验证
GysypmlControl gysypmlControl = this
.findGysypmlControlByGysyisAndYpxxid(usergysid, ypxxid);
if (gysypmlControl == null)// 如果查出来为空,说明还不存在这条数据了,我们就可以插入数据了。
{ String cotrol = systemConfigService.findBasicinfoById("00101").getValue();//设置药品的控制状态。默认是1(正常状态)。
//但是为了去除硬编码,我们从系统文件中去读取控制信息。
GysypmlControl gysypmlControl2 = new GysypmlControl();
gysypmlControl2.setId(UUIDBuild.getUUID());// 设置uuid的主键
gysypmlControl2.setUsergysid(usergysid);
gysypmlControl2.setYpxxid(ypxxid);
gysypmlControl2.setControl(cotrol);
gysypmlControlMapper.insert(gysypmlControl2); } }

035医疗项目-模块三:药品供应商目录模块——供货商药品目录(批量)添加药品的功能---------Service的更多相关文章

  1. 潭州课堂25班:Ph201805201 django 项目 第三十三课 后台文章标签查询提交到前台,删除功能实现(课堂笔记)

    在视图中创建个类,要实现此功能,并把结果返回前台 , from django.shortcuts import render from django.views import View from dj ...

  2. 030医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------Dao层:基本的查询语句的编写

    我们安装显示的要求: 我们能看到显示的目录里面有:供货企业的名字(这个数据来自于供货商的表[usergys]),流水号,通用名,剂型(这些都来自药品信息表),供货的状态(这个呢在gysypml_con ...

  3. 036医疗项目-模块三:药品供应商目录模块——供货商药品目录(批量)添加药品的功能---------Action层

    这篇文章我们来讲Action层: 我们先讲开发步骤: 1:我们要根据Service层里面要传的参数,在Action层传入对应的参数. Service层是:public void insertGysym ...

  4. 023医疗项目-模块二:药品目录的导入导出-从数据库中查出数据用XSSF导出excel并存放在虚拟目录最后下载(包括调试)

    我们要实现的效果:     进入到这个页面后,输入要查询的条件,查询出药品表的数据,然后按下导出按钮 ,就会在服务器的一个目录下生成一个药品表的excel表格.  点击"导出"之后 ...

  5. 044医疗项目-模块四:采购单模块—采购单保存(Dao,Service,Action三层)

    我们上上一篇文章(042医疗项目-模块四:采购单模块-采购单明细添加查询,并且把数据添加到数据库中)做的工作是把数据插入到了数据库,我们这篇文章做的是042医疗项目-模块四:采购单模块-采购单明细添加 ...

  6. 005医疗项目-模块一:用户的查找:1.用户表查询的sql语句

    这是医疗项目的第一个模块:做一个用户的查询,可以根据用户的账号,用户的名称,单位的名称,用户的类型去查询.要求效果如下:

  7. 045医疗项目-模块四:采购单模块—采购单提交(Dao,Service,Action三层)

    我们之前做的就是采购单的编辑,在采购单里面添加了药品,然后我们这篇文章要做的就是说提交这个采购单. 当我们创建完成采购单,确定采购单不再修改,需要提交采购单,由监管单位进行审核. 我们在提交这个采购单 ...

  8. 043医疗项目-模块四:采购单模块—采购单明细查询(Dao,Service,Action三层)

    前一篇文章我们做的是在医院的角度上添加在采购单里面添加药品.这一篇文章是查看我们添加的采购单信息. 我们先看一下要实现的效果:当: 按下确认添加时,会在这里 显示出刚才添加的数据. 好,我们就来做这个 ...

  9. 010医疗项目-模块一:用户添加的实现(Dao,Service,Action,增加页面调试,提交页面调试)

    要实现的效果:

随机推荐

  1. iOS KVO概述

    iOS KVO概述 面试中经常会被问到:什么是KVO?这个问题既然出现概率这么大,那么我们就来详细讲一讲到底什么是KVO.下次再有面试官问你的时候,你就可以娓娓道来,以彰显高逼格 概述 问:什么是KV ...

  2. 转载:检测到有潜在危险的 Request.Form 值

    转载:检测到有潜在危险的 Request.Form 值 金刚 ASP.NET Request.Form 这是一篇转载的文章,文章原始出处.点我 这种问题是因为你提交的Form中有HTML字符串,例如你 ...

  3. jquery操作select(取值,设置选中)

    最近工作中总出现select 和 option问题,整理一下,内容大部分源于网络资料 一.基础取值问题 例如<select class="selector"></ ...

  4. java获取客户端ID地址

    转:http://zhenchengchagangzi.iteye.com/blog/1199300#bc2372048 在JSP里,获取客户端的IP地址的方法是:request.getRemoteA ...

  5. go sync.Mutex 设计思想与演化过程 (一)

    go语言在云计算时代将会如日中天,还抱着.NET不放的人将会被淘汰.学习go语言和.NET完全不一样,它有非常简单的runtime 和 类库.最好的办法就是将整个源代码读一遍,这是我见过最简洁的系统类 ...

  6. Sqlite学习笔记(四)&&SQLite-WAL原理

    Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...

  7. R语言中的循环函数(Grouping Function)

    R语言中有几个常用的函数,可以按组对数据进行处理,apply, lapply, sapply, tapply, mapply,等.这几个函数功能有些类似,下面介绍下这几个函数的用法. Apply 这是 ...

  8. 简析一下SQL Server里面Fast_Forword 和 SRROLL 的区别

    这次简单说说游标的分类. 先看看通常游标的语法 DECLARE cursor_name CURSOR [ LOCAL :局部游标,仅在当前会话有效 | GLOBAL : 全局游标,全局有效,可以 ] ...

  9. SHA-1 加密算法破解现已只需要 10 天

    转自:http://www.linuxeden.com/html/news/20151009/163173.html SHA-1是如今很常见的一种加密哈希算法,HTTPS传输和软件签名认证都很喜欢它, ...

  10. Java设计模式 - 观察者模式

    定义 观察者模式属于对象行为型模式. 在对象之间定义一对多的依赖,这样一来当一个对象改变状态,依赖它的对象都会收到通知并自动更新. 优点 1.  主题和观察者之间抽象耦合.无论什么对象主要实现了特定的 ...