一、通用插入操作

/**
*
* 编写一个服务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项目学习——阶段性小结——插入数据的更多相关文章

  1. Ofbiz项目学习——阶段性小结——删除数据

    一.根据主键进行删除 /** * 按主键进行删除 * @param dctx * @param context * @return */ public static Map<String,Obj ...

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

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

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

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

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

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

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

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

  6. Java项目往数据库中插入数据,出现中文乱码

    项目环境: JSP+Servlet+Mysql数据库 需要检查的地方: 1. java项目整体的编码格式为utf-8.并且将数据传递给数据库之前,数据是否依旧是正常的(可以通过打断点的方式一步步跟踪查 ...

  7. JDBC基础学习(五)—批处理插入数据

    一.批处理介绍      当需要成批插入或者更新记录时.可以采用Java的批量更新机制,这一机制允许多条语句一次性提交给数据库批量处理.通常情况下比单独提交处理更有效率. JDBC的批量处理语句包括下 ...

  8. CUBRID学习笔记 22 插入数据

    CREATE TABLE auto_tbl(id INT AUTO_INCREMENT, name VARCHAR); 自增长的列可以插入null, 同时一次可以插入多条记录.别的和其他的sql数据库 ...

  9. 吴裕雄--天生自然 PHP开发学习:MySQL 插入数据

    <?php $servername = "localhost"; $username = "root"; $password = "admin& ...

随机推荐

  1. Beta冲刺(3/7)——2019.5.25

    作业描述 课程 软件工程1916|W(福州大学) 团队名称 修!咻咻! 作业要求 项目Beta冲刺(团队) 团队目标 切实可行的计算机协会维修预约平台 开发工具 Eclipse 团队信息 队员学号 队 ...

  2. history 用法大全

     history 命令用于显示指定数目的指令命令,读取历史命令文件中的目录到历史命令缓冲区和将历史命令缓冲区中的目录写入命令文件.   语法 history  [options]  [file]   ...

  3. Java多线程分批发送消息的小例子

    需求: 假设有10万个用户,现在节假日做活动,需要给每个用户发送一条活动短信,为了提高程序的效率,建议使用多线程分批发送. 这里值得注意的是: 每开一个线程都会占用CPU的资源,所以线程根据所需要的条 ...

  4. 关于visual studio 2015 智能提示英文,而非中文的解决方案

    关于visual studio 2015 智能提示英文,而非中文的解决方案:   找到这个目录 C:\Program Files (x86)\Reference Assemblies\Microsof ...

  5. 文件的读取(txt文件)

    一.将读取文件夹内容,变为字典保存,代码如下: def read_class_names(class_file_name): '''loads class name from a file''' na ...

  6. 异常---Day21(写得有错请指出,感谢)

    异常的概念 异常,就是不正常的意思.在生活中:医生说,你的身体某个部位有异常,该部位和正常相比有点不同,该部位的功能将受影响.在程序中的意思就是:指的是程序在执行过程中,出现的非正常的情况,终会导致J ...

  7. JS面向对象设计-理解对象

    不同于其他面向对象语言(OO,Object-Oriented),JS的ECMAScript没有类的概念, 它把对象定义为"无序属性(基本值.对象.函数)的集合",类似于散列表. 每 ...

  8. 【转载】 C#中ArrayList集合类的使用

    在C#的集合操作过程中,我们一般常用的集合类为List集合,List集合是一种强类型的泛型集合,其实还有一个ArrayList集合类,ArrayList集合类则非泛型类的集合,并且ArrayList集 ...

  9. CSS怎么隐藏滚动条(三种方法)

    xhtml中隐藏滚动条在用ie6浏览有框架的xhtml页面的时候,默认会水平和垂直滚动条会一起出现,这是ie6的一个bug,在firefox上是正常的,出现的原因是其对XHTML 1.0 transi ...

  10. Palo Alto GlobalProtect上的PreAuth RCE

    0x00 前言 SSL VPN虽然可以保护企业资产免受互联网被攻击的风险影响,但如果SSL VPN本身容易受到攻击呢?它们暴露在互联网上,可以可靠并安全地连接到内网中.一旦SSL VPN服务器遭到入侵 ...