Ofbiz项目学习——阶段性小结——删除数据
一、根据主键进行删除
/**
* 按主键进行删除
* @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项目学习——阶段性小结——删除数据的更多相关文章
- Ofbiz项目学习——阶段性小结——更新数据
一.根据一个字段进行修改 /** * 根据一个字段进行修改(这个条件字段可以是主键, 也可以不是主键) * @param dctx * @param context * @return */ publ ...
- Ofbiz项目学习——阶段性小结——插入数据
一.通用插入操作 /** * * 编写一个服务createUomOneDemo, * 该服务的作用是在表Uom中增加一条记录,其中: * 字段uomId的值为“BaseLineProduct”. * ...
- Ofbiz项目学习——阶段性小结——视图
一.简要介绍 1.按照SQL的视图概念:在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表.视图包含行和列,就像一个真实的表.视图中的字段就是来自一个或多个数据库中的真实的表中的字段. 2. ...
- Ofbiz项目学习——阶段性小结——查询
一.组装参数的学习 首先是查询条件,对于查询条件,需要判断是否从前端传递空值?——怎么处理查询空值? 当然可以一个一个进行判断,但是这样代码会导致很多,可以统一处理,形成一个公共方法. 1. 单个处理 ...
- Ofbiz项目学习——阶段性小结——服务返回结果
一.返回成功 1.在.DispatcherReturnDemoService类中编写服务[returnSuccess],内容如下: /** * 返回成功结果 * @param dctx * @para ...
- MongoDB 学习笔记之 删除数据,集合,数据库
删除数据,集合,数据库: 删除一个文档: db.media.deleteOne({"name": "Sky"}) 删除多个文档: db.media.delete ...
- [20190213]学习bbed-恢复删除的数据.txt
[20190213]学习bbed-恢复删除的数据.txt --//以前也做过类似测试,当时在用bbed做verify时错误都不处理,当时的想法就是能读出就ok了.--//而且当时也做成功,纯粹是依葫芦 ...
- Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)
1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...
- Cassandra1.2文档学习(11)—— 删除数据
参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_about_ ...
随机推荐
- win7下每次打开Excel2007都提示向程序发送命令时出现问题的解决方案
每次打开Excel2007都提示向程序发送命令时出现问题,要打开两次才可以打开,下面介绍该问题的解决办法. 第一种情况:也就是屏蔽DDE的解决方案,这是大多数人都是这种情况,该情况的解决办法: exc ...
- hadoop学习之HDFS原理
HDFS原理 HDFS包括三个组件: NameNode.DataNode.SecondaryNameNode NameNode的作用是存储元数据(文件名.创建时间.大小.权限.与block块映射关系等 ...
- sqlserver替换一个单引号为多个单引号
SqlServer Where语句中如果有单引号,需要替换为两个单引号,不然会语法错误,替换方法如下REPLACE(@UserName,'''','''''') REPLACE(@UserName,' ...
- MODBUS 数据格式相关记录
串口通讯格式: 串口通讯可以分为同步通讯(Synchronous)和异步通讯(Asynchronous).同步通讯时有一根时钟信号,数据格式中没有起始位和停止位:异步通讯中没有时钟信号,数据格式中包含 ...
- my first blog by cnblogs
#include <stdio.h> int main() { printf("hello everyone."); ; } 上面为我的第一个C语言测试代码,仅供初学者 ...
- WPF USB设备采集开源工具介绍
最近项目需要需要试试采集电脑USB 设备信息 找到了 开源 示例 代码非常好 公共库也很友好 可能知名度太低 才4star https://github.com/vurdalakov/usbd ...
- opencv常用数据结构
2019/10/29 1.Mat 成员函数:cols.rows.channels.ptr获取任意行的首地址.at处理像素 2.InputArray/OutArray相当于Mat 2019/11/4 1 ...
- asp.net core 系列之Reponse caching 之 Response Caching Middleware(4)
这篇文章介绍 Response Caching Middleware . Response Caching Middleware in ASP.NET Core 通过在ASP.NET Core应用中 ...
- WPF解决WindowsFormsHost背景透明
项目案例:WPF使用WindowsFormsHost播放视频,视频上显示边框.字幕等特效: 难点问题 1.WindowsFormsHost不支持背景透明: 2.WPF Panel.ZIndex无效,W ...
- Socker编程之TCP
一:TCP介绍 TCP协议,传输控制协议(英语:Transmission Control Protocol,缩写为 TCP)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由IETF的RFC 7 ...