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& ...
随机推荐
- [转帖]统一操作系统 UOS 龙芯版上线
统一操作系统 UOS 龙芯版上线 看评论很有必要 搞一波 深度的操作系统了https://www.oschina.net/news/112065/chinauos-with-loongson?p=4 ...
- FusionInsight大数据开发---Flume应用开发
Flume应用开发 要求: 了解Flume应用开发适用场景 掌握Flume应用开发 Flume应用场景Flume的核心是把数据从数据源收集过来,在送到目的地.为了保证输送一定成功,发送到目的地之前,会 ...
- asp.net core 系列之Reponse caching 之 Response Caching Middleware(4)
这篇文章介绍 Response Caching Middleware . Response Caching Middleware in ASP.NET Core 通过在ASP.NET Core应用中 ...
- C# LINQ干掉for循环
public void OldSum() { ; ; i < ; i++) { sum0 += i; } Assert.AreEqual(, sum0); } public void NewSu ...
- Java正则表达式校验QQ号码和邮箱地址格式
public class Demo02 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); ...
- Linux环境:VMware下windows虚拟机与linux主机进行文件共享的方法
操作主要分两大步骤: 一.是对主机进行配置: 二.是在虚拟机上直接连接共享目录. 一.主机配置 1.打开VMware虚拟机,双击需要进行文件共享的虚拟机.如下图,双击CentOS 64位(以linux ...
- web基础运用
目录 web框架 web应用本质 Web应用程序的优点 Web应用程序的缺点 BS架构优点 web框架的分类 web框架包含了三部分 web框架分类 Http协议 路由系统 自定制的web框架案例 w ...
- CSS中:和::
一个冒号是伪类,两个冒号是伪元素 伪类可以独立于文档的元素来分配样式,且可以分配给任何元素,逻辑上和功能上类类似,但是其是预定义的.不存在于文档树中且表达方式也不同,所以叫伪类.伪元素所控制的内容和一 ...
- 解决javaScript在不同时区new Date()显示值不同问题
在日期格式化时遇到的问题,日期格式化方法在最下面 如果在中国时区 formatDate('2019-07-09') 结果是 ‘2019-07-09’ 如果 在夏威夷时区 utc-10:00 或 ...
- js学习之存储
一.Cookie和Session的区别 1.cookie数据存放在客户的浏览器上,session数据放在服务器上(一般以内存.数据库.文件形式). 2.session会在一定时间内保存在服务器上.当访 ...