一、根据主键进行删除

	/**
* 按主键进行删除
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> deleteUomByPrimaryKey(
DispatchContext dctx, Map<String,Object> context){ //取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //TODO 在这里考虑的不是很全面, 还需要讨论一下: 1) MiscMap方式 2) delegator.makePKSingle方法
Map<String,Object> pkFields = FastMap.newInstance();
pkFields.put("uomId", "BaseLineProduct"); //这里删除前面创建的基线产品信息
GenericPK primaryKey = delegator.makePK("Uom", pkFields);
try {
//执行按主键删除操作
delegator.removeByPrimaryKey(primaryKey);
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0002,primaryKey.toString());
}
//把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}

二、根据多条件进行删除

	/**
* 按多条件进行删除, 并且这些条件是'与' 的关系, 一般是当删除条件为非主键时使用
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> deleteUomByOtherFields(DispatchContext dctx, Map<String,Object> context){ //取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //TODO 在这里考虑的不是很全面, 还需要讨论一下: MiscMap方式 //这里删除前面创建的现金管理系统信息
Map<String,Object> deleteFields = FastMap.newInstance();
deleteFields.put("abbreviation", "Cashm");
deleteFields.put("description", "现金管理系统");
try {
//根据设定的条件执行删除操作
delegator.removeByAnd("Uom", deleteFields);
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0002,deleteFields.toString());
}
//把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}

三、根据一个字段有多个值时进行删除

/**
* 根据一个字段的多个值,删除记录
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> deleteUomByMoreValues(DispatchContext dctx, Map<String,Object> context){ //取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //这里删除前面创建的"基线产品信息"和"现金管理系统信息"
Map<String,Object> deleteFields = FastMap.newInstance();
deleteFields.put("abbreviation", "BLP");
deleteFields.put("abbreviation", "Cashm"); //收集删除条件
EntityCondition deleteBLPCon = EntityCondition.makeCondition("abbreviation", EntityOperator.EQUALS, "BLP");
EntityCondition deleteCashmCon = EntityCondition.makeCondition("abbreviation", EntityOperator.EQUALS, "Cashm");
EntityCondition deleteCondition = EntityCondition.makeCondition(deleteBLPCon, EntityOperator.OR, deleteCashmCon);
try {
System.err.println("删除条件: " + deleteCondition.toString());
//根据设定的条件执行删除操作
delegator.removeByCondition("Uom", deleteCondition);
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0002,deleteCondition.toString());
}
//把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}

四、根据时间段进行删除

	/**
* 删除一个时间段内的数据
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> deleteUomByDate(DispatchContext dctx, Map<String,Object> context){ //取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //从输入参数中取出开始日期和结束日期
String beginDateStr = (String) context.get("beginDate");
String endDateStr = (String) context.get("endDate"); //设置查询条件: 记录时间 大于 beginDate ,记录时间 小于 endDate
List<EntityCondition> conList = FastList.newInstance(); //如果传入的开始日期不为空,则设置删除条件: 删除的记录不能早于开始日期
if( UtilValidate.isNotEmpty(beginDateStr)){
try {
//先把开始日期的字符串转成Timestamp格式
Timestamp beginDate = UtilDateTime.stringToTimeStamp(beginDateStr, InnerConstant.DATE_FORMAT, TimeZone.getDefault(), Locale.CHINA);
//再把整个日期的时间部分设置成 00:00:00.000
beginDate = UtilDateTime.getDayStart(beginDate);
//设置查询条件: 记录时间 大于 beginDate
EntityCondition startDateCon = EntityCondition.makeCondition("createdStamp", EntityOperator.GREATER_THAN_EQUAL_TO, beginDate);
conList.add(startDateCon);
} catch (ParseException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0003,beginDateStr,e.getMessage());
}
} //如果传入的结束日期不为空, 则设置删除条件: 删除的记录不能晚于结束日期
if( UtilValidate.isNotEmpty(endDateStr)){
try {
//先把结束日期的字符串转成Timestamp格式
Timestamp endDate = UtilDateTime.stringToTimeStamp(endDateStr, InnerConstant.DATE_FORMAT, TimeZone.getDefault(), Locale.CHINA);
System.err.println(endDate.toString());
//再把结束日期的时间部分设置成: 23:59:59.999
endDate = UtilDateTime.getDayEnd(UtilDateTime.nowTimestamp());
//设置查询条件: 记录时间 小于 endDate
EntityCondition endTimeCon = EntityCondition.makeCondition("createdStamp", EntityOperator.LESS_THAN_EQUAL_TO, endDate);
conList.add(endTimeCon);
} catch (ParseException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0004,endDateStr,e.getMessage());
}
}
EntityCondition deleteCondition = EntityCondition.makeCondition(conList, EntityOperator.AND); try {
//根据设定的条件执行删除操作
delegator.removeByCondition("Uom", deleteCondition);
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0002,deleteCondition.toString());
}
//把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}

XML配置

	<service name="deleteUomByDate" engine="java"
location="com.giantstone.bosent.demo.delegator.DelegatorDeleteDemoService" invoke="deleteUomByDate">
<attribute name="beginDate" type="String" mode="IN" optional="true" />
<attribute name="endDate" type="String" mode="IN" optional="true" />
<attribute name="returnCode" type="Map" mode="OUT" optional="true" />
</service>

 注意:时间转化

//先把开始日期的字符串转成Timestamp格式
Timestamp beginDate = UtilDateTime.stringToTimeStamp(beginDateStr, InnerConstant.DATE_FORMAT, TimeZone.getDefault(), Locale.CHINA);
//再把整个日期的时间部分设置成 00:00:00.000
beginDate = UtilDateTime.getDayStart(beginDate);
beginDate = DateTimeUtil.utilDateTosqlDate(startTime.concat(AgentInspectorFields.START_TIME_STR));

调用方法如下:

    /** 开始时间 **/
public static final String START_TIME_STR = " 00:00:00"; /** 结束时间**/
public static final String END_TINE_STR = " 23:59:59"; public static java.sql.Date utilDateTosqlDate(String utilDate)
throws BusinessException {
if (UtilValidate.isEmpty(utilDate)) {
return null;
} else {
return utilDateTosqlDate(stringToDate(utilDate));
}
} public static java.sql.Date utilDateTosqlDate(Date utilDate)
throws BusinessException {
if (UtilValidate.isEmpty(utilDate)) {
return null;
} else {
java.sql.Date sqlDate = new java.sql.Date(utilDate.getTime());
return sqlDate;
}
}

  

  

												

Ofbiz项目学习——阶段性小结——删除数据的更多相关文章

  1. Ofbiz项目学习——阶段性小结——更新数据

    一.根据一个字段进行修改 /** * 根据一个字段进行修改(这个条件字段可以是主键, 也可以不是主键) * @param dctx * @param context * @return */ publ ...

  2. Ofbiz项目学习——阶段性小结——插入数据

    一.通用插入操作 /** * * 编写一个服务createUomOneDemo, * 该服务的作用是在表Uom中增加一条记录,其中: * 字段uomId的值为“BaseLineProduct”. * ...

  3. Ofbiz项目学习——阶段性小结——视图

    一.简要介绍 1.按照SQL的视图概念:在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表.视图包含行和列,就像一个真实的表.视图中的字段就是来自一个或多个数据库中的真实的表中的字段. 2. ...

  4. Ofbiz项目学习——阶段性小结——查询

    一.组装参数的学习 首先是查询条件,对于查询条件,需要判断是否从前端传递空值?——怎么处理查询空值? 当然可以一个一个进行判断,但是这样代码会导致很多,可以统一处理,形成一个公共方法. 1. 单个处理 ...

  5. Ofbiz项目学习——阶段性小结——服务返回结果

    一.返回成功 1.在.DispatcherReturnDemoService类中编写服务[returnSuccess],内容如下: /** * 返回成功结果 * @param dctx * @para ...

  6. MongoDB 学习笔记之 删除数据,集合,数据库

    删除数据,集合,数据库: 删除一个文档: db.media.deleteOne({"name": "Sky"}) 删除多个文档: db.media.delete ...

  7. [20190213]学习bbed-恢复删除的数据.txt

    [20190213]学习bbed-恢复删除的数据.txt --//以前也做过类似测试,当时在用bbed做verify时错误都不处理,当时的想法就是能读出就ok了.--//而且当时也做成功,纯粹是依葫芦 ...

  8. Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)

    1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...

  9. Cassandra1.2文档学习(11)—— 删除数据

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_about_ ...

随机推荐

  1. python入门之数据类型及内置方法

    目录 一.题记 二.整形int 2.1 用途 2.2 定义方式 2.3 常用方法 2.3.1 进制之间的转换 2.3.2 数据类型转换 3 类型总结 三.浮点型float 3.1 用途 3.2 定义方 ...

  2. [转帖]JVM性能调优详解

    JVM性能调优详解 https://www.cnblogs.com/secbro/p/11833651.html 应该是 jdk8 以前的方法 貌似permsize 已经放弃这一块了. 前面我们学习了 ...

  3. 最细的eclipse 安装maven踩过的坑

    Eclipse安装maven插件踩过的坑 在线安装maven eclipse安装maven插件,在网上有各种各样的方法,博主使用过的也不止一种,但是留下的印象总是时好时不好,同样的方法也不确定那一次能 ...

  4. kafka Authentication using SASL/Kerberos

    Authentication using SASL/Kerberos Prerequisites KerberosIf your organization is already using a Ker ...

  5. session中删除数组中的某一个值 - 购物车例子 - jsp

    这篇随笔简单的讲一下在session中移除数组中的某一项内容,比如这里有一个购物车其中有两件商品,需要移除其中洗发水这一件商品. 其实在这个session对象中存储了一个数组,在订购页面时选择商品加入 ...

  6. 不用Pageant告别Pageant Windows10下TortoiseGit和Git配置使用同一SSH密钥

    关于Git使用SSH免密连接参考:https://blog.csdn.net/qq_32786873/article/details/80570788 关于Windows10下TortoiseGit使 ...

  7. java 泛型和object比较

    引言 我们使用object和泛型做形参,都是为了让这个方法能接收更多类型的对象,让程序变得更健壮,代码复用率更高.当我们回看自己写的代码时会发现,好像使用泛型的地方使用object也可以,使用obje ...

  8. vuex简单化理解和安装使用

     1.简单化理解 首先你要明白 vuex 的目的 就是为了 集中化的管理项目中 组件所有的 数据状态 (state) 0. 第一步你要明白 , store 的重要性 , store 类似一个中央基站, ...

  9. 如何显示IntelliJ IDEA工具的Run Dashboard功能(转)

    从 JetBrains released IntelliJ IDEA 2017.2.1 版本之后,新出的功能‘Run Dashboard,它能非常方便的提供开发人员查看本地springboot服务运行 ...

  10. 剑指前端(前端入门笔记系列)——DOM(元素节点)

    DOM(元素节点) 本文介绍了元素节点的基本操作:增删改查   增 新增一个元素节点分为两步(二者缺一不可),第一步:创建元素节点,第二步:将创建的元素节点插入到指定元素节点中(也就是插入指定元素节点 ...