Ofbiz项目学习——阶段性小结——插入数据
一、通用插入操作
/**
*
* 编写一个服务createUomOneDemo,
* 该服务的作用是在表Uom中增加一条记录,其中:
* 字段uomId的值为“BaseLineProduct”、
* 字段abbreviation的值为“BLP”、
* 字段description的值为“基线产品”
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> createUomOneDemo(
DispatchContext dctx, Map<String,Object> context)
{ //取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //创建一条Uom记录的对象
GenericValue oneUom = delegator.makeValue("Uom"); //向其中加入每个字段对应的数据
oneUom.setString("uomId","BaseLineProduct");
oneUom.setString("abbreviation", "BLP");
oneUom.setString("description", "基线产品"); try {
//保存到数据库的Uom表中
oneUom.create();
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
Return ReturnMapUtil.getErrorMap(
DemoErrorMapping.BASE0001,oneUom.toString());
}
//把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}
二、自动产生主键的插入操作(一)
/**
*
* 编写一个服务createUomTwoDemo,
* 该服务的作用是在表Uom中增加一条记录,其中:
* 字段uomId要求自动生成、
* 字段abbreviation的值为“Cashm”,
* 字段description的值为“现金管理系统”
* @param dctx
* @param context
* @return
*/
public static Map<String,Object> createUomTwoDemo(DispatchContext dctx, Map context){
//取得实体引擎实例
GenericDelegator delegator = dctx.getDelegator(); //创建一条Uom记录的对象
GenericValue oneUom = delegator.makeValue("Uom"); //向其中加入每个字段对应的数据
String uomId = delegator.getNextSeqId("Uom"); //该方法用于自动创建一个实体的主键编号, 这里创建了Uom表的主键(uomId)的编号
oneUom.setString("uomId",uomId);
oneUom.setString("abbreviation", "Cashm");
oneUom.setString("description", "现金管理系统");
/**
* 一般通过如下代码添加属性
* Map<String,Object> fields = FastMap.newInstance();
* String uomId = delegator.getNextSeqId("Uom");
* fields.put("uomId",uomId);
* fields.put("abbreviation","Cashm");
* fields.put("description","现金管理系统");
* GenericValue SingleUom = delegator.makeValue("Uom", fields);
* SingleUom.create();
*/ try {
//保存到数据库的Uom表中
oneUom.create();
} catch (GenericEntityException e) {
//则把错误信息以Error级别打印到日志文件中
Debug.logError(e, module);
//把指定的错误码对应的描述信息返回给服务调用者
return ReturnMapUtil.getErrorMap(DemoErrorMapping.BASE0001,oneUom.toString());
} //把表示成功的信息返回给服务调用者
return ReturnMapUtil.getSuccessMap();
}
}
二、自动产生主键的插入操作(二)
// 委托引擎
Delegator delegator = dctx.getDelegator();
// 获取GenericValue
GenericValue genericValue = delegator.makeValue("实体映射表名称");
// 获取自增主键
genericValue.setNextSeqId();
// 设置非主键字段 Map<? extends Object, ? extends Object> fields
genericValue.setNonPKFields(fields);
// 还有一些需要单独处理
genericValue.set(key, value, true);
// 创建一条记录
GenericValue oneRecord = delegator.create(genericValue);
// 如果需要获取主键id
Object id = oneRecord.get("id");
Ofbiz项目学习——阶段性小结——插入数据的更多相关文章
- Ofbiz项目学习——阶段性小结——删除数据
一.根据主键进行删除 /** * 按主键进行删除 * @param dctx * @param context * @return */ public static Map<String,Obj ...
- Ofbiz项目学习——阶段性小结——更新数据
一.根据一个字段进行修改 /** * 根据一个字段进行修改(这个条件字段可以是主键, 也可以不是主键) * @param dctx * @param context * @return */ publ ...
- Ofbiz项目学习——阶段性小结——视图
一.简要介绍 1.按照SQL的视图概念:在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表.视图包含行和列,就像一个真实的表.视图中的字段就是来自一个或多个数据库中的真实的表中的字段. 2. ...
- Ofbiz项目学习——阶段性小结——查询
一.组装参数的学习 首先是查询条件,对于查询条件,需要判断是否从前端传递空值?——怎么处理查询空值? 当然可以一个一个进行判断,但是这样代码会导致很多,可以统一处理,形成一个公共方法. 1. 单个处理 ...
- Ofbiz项目学习——阶段性小结——服务返回结果
一.返回成功 1.在.DispatcherReturnDemoService类中编写服务[returnSuccess],内容如下: /** * 返回成功结果 * @param dctx * @para ...
- Java项目往数据库中插入数据,出现中文乱码
项目环境: JSP+Servlet+Mysql数据库 需要检查的地方: 1. java项目整体的编码格式为utf-8.并且将数据传递给数据库之前,数据是否依旧是正常的(可以通过打断点的方式一步步跟踪查 ...
- JDBC基础学习(五)—批处理插入数据
一.批处理介绍 当需要成批插入或者更新记录时.可以采用Java的批量更新机制,这一机制允许多条语句一次性提交给数据库批量处理.通常情况下比单独提交处理更有效率. JDBC的批量处理语句包括下 ...
- CUBRID学习笔记 22 插入数据
CREATE TABLE auto_tbl(id INT AUTO_INCREMENT, name VARCHAR); 自增长的列可以插入null, 同时一次可以插入多条记录.别的和其他的sql数据库 ...
- 吴裕雄--天生自然 PHP开发学习:MySQL 插入数据
<?php $servername = "localhost"; $username = "root"; $password = "admin& ...
随机推荐
- sql优化(原理,方法,特点,实例)
整理的有点多,做好心理准备...... 1.资源优化理解: 不同设备,io不同.每种设备都有两个指标:延时(响应时间):表示硬件的突发处理能力:带宽(吞吐量):代表硬件持续处理能力. 每种硬件主要的工 ...
- windowsServer-------- 系统中调出文件扩展名
Windows Server是微软发布的一系列服务器操作系统的品牌名. 各个品牌的发布日期 Windows Server 2003 (2003年4月) Windows Server 2003 R2(2 ...
- Jvm内存总结
对于不同的Jvm及不同的jdk版本内存模型不同 内存区域 名称 作用 参数 异常 分析方法 解决方案 Heap 堆内存 存储对象 -Xms -Xmx Java.lang.OutOfMemeoryErr ...
- react 中 Modal 多次使用且带参数不同实现
一.举例:对于 echatrs 的柱子分别需要弹窗 带参数 触发弹窗出现事件 showModalhref myChart.on('click', (params) => { switch (pa ...
- 【题解】PERIOD - Period [POJ1961] [SP263]
[题解]PERIOD - Period [POJ1961] [SP263] 在进入这道题之前,我们需要了解 kmp 算法 不知道的童鞋可以去看一下Silent_EAG(一个可爱的女孩纸)的讲解. 关于 ...
- NVDLA软件架构和源码解析 第一章—内核驱动【华为云技术分享】
驱动整体设计介绍 不同的processor Nvidia DLA的内核驱动KMD(Kernel mode driver)中,并不是把DLA当成一个设备来控制,而是把不同的功能模块当做不同的proces ...
- RocketMQ Release Note(RocketMQ升级日志译文)
RocketMQ升级日志 1 4.2.0 原版Release Note 1.1 New Feature 支持传输层安全性 客户端支持log4j2 PushConsumer支持条数与大小维度的流控 1. ...
- C# - Array.Sort()方法
Array类简介 Array类是C#中所有数组的基类.我们常用的[]声明数组即为Array类的语法,我们可通过Array类提供的各种方法对C#中数组进行操作.最典型的就是数组排序 Array.Sort ...
- 解决v-html无法理解vue模版的问题-动态获取模版,动态插入app并使用当下app状态数据需求
很多情况下,我们需要使用动态的html作为某个dom元素的inner html,如果这个内容是标准的html的话,则v-html能够圆满满足需求,而如果内容包含了vue组件,则使用v-html就不能达 ...
- OpenResty下载安装教程
原文链接:http://www.studyshare.cn/software/details/1174/0 一.OpenResty简介 OpenResty是一个全功能的 Web 应用服务器.它打包了标 ...