单据分页的实现

单据分页的实现

1. AceWzcgfkjtMaintainProxy.java

在这里插入图片描述

package nc.ui.jych.wzcgfkjt.ace.serviceproxy;import nc.bs.framework.common.NCLocator;
import nc.itf.jych.IWzcgfkjtMaintain;
import nc.ui.uif2.components.pagination.IPaginationQueryService;
import nc.vo.jych.wzcgfkjt.AggWzcgfkjtVO;
import nc.vo.pub.BusinessException;
import nc.vo.pubapp.pattern.exception.ExceptionUtils;/*** 示例单据的操作代理* * @author author* @version tempProject version*/
public class AceWzcgfkjtMaintainProxy implements IPaginationQueryService {@Overridepublic Object[] queryObjectByPks(String[] pks)throws BusinessException {// TODO 自动生成的方法存根AggWzcgfkjtVO[] aggvo = null;IWzcgfkjtMaintain query = NCLocator.getInstance().lookup(IWzcgfkjtMaintain.class);try {aggvo = query.queryBillByPK(pks);} catch (Exception e) {ExceptionUtils.wrappException(e);}return aggvo;}}

2. Wzcgfkjt_config.xml

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

<!--分页新增这三个bean-->
<bean id="maintainProxy" class="nc.ui.jych.wzcgfkjt.ace.serviceproxy.AceWzcgfkjtMaintainProxy" /><bean id="paginationModel" class="nc.ui.pubapp.uif2app.model.pagination.PubPaginationModel"init-method="init"><property name="paginationQueryService" ref="maintainProxy" />
</bean><bean id="paginationBar" class="nc.ui.uif2.components.pagination.PaginationBar" init-method="onStructChanged"><property name="paginationModel" ref="paginationModel" />
</bean><!-- 应用服务类,负责进行模型操作的处理 -->
<bean id="bmModelModelService" class="nc.ui.jych.wzcgfkjt.ace.serviceproxy.AceWzcgfkjtMaintainProxy"/><!--分页新增这二个bean-->
<bean id="bmModelModelDataManager" class="nc.ui.pubapp.uif2app.model.pagination.PaginationModelDataManager"><property name="model" ref="bmModel"></property><property name="paginationModel" ref="paginationModel" /><property name="pageQueryService" ref="pageQueryService" />
</bean><bean id="pageQueryService" class="nc.ui.pubapp.uif2app.model.pagination.UIPageQueryService"><property name="allPagePkQueryServiceMethod" value="nc.itf.jych.IWzcgfkjtMaintain.queryPKs"></property><property name="dataOfPksQueryServiceMethod" value="nc.itf.jych.IWzcgfkjtMaintain.queryBillByPK"></property>
</bean><!--分页新增这个property-->
<property name="paginationBar" ref="paginationBar" />

3. AceWzcgfkjtPubServiceImpl.java

在这里插入图片描述

package nc.impl.pub.ace;import java.util.ArrayList;
import java.util.List;import nc.bs.framework.common.InvocationInfoProxy;
import nc.bs.framework.common.NCLocator;
import nc.impl.pubapp.pattern.data.bill.BillQuery;
import nc.impl.pubapp.pattern.database.DataAccessUtils;
import nc.itf.uap.IUAPQueryBS;
import nc.jdbc.framework.processor.ArrayListProcessor;
import nc.jdbc.framework.processor.ColumnProcessor;
import nc.ui.querytemplate.querytree.IQueryScheme;
import nc.vo.jych.wzcgfkjt.AggWzcgfkjtVO;
import nc.vo.pub.BusinessException;
import nc.vo.pubapp.bill.pagination.util.PaginationUtils;
import nc.vo.pubapp.pattern.data.IRowSet;
import nc.vo.pubapp.pattern.exception.ExceptionUtils;
import nc.vo.pubapp.pattern.pub.SqlBuilder;
import nc.vo.pubapp.query2.sql.process.QuerySchemeProcessor;
import nc.vo.zkch.utils.NullValueUtils;public abstract class AceWzcgfkjtPubServiceImpl {//分页查询方法,根据PK查单据public AggWzcgfkjtVO[] pubquerybillbypkbills(String[] pks) {AggWzcgfkjtVO[] bills = null;BillQuery<AggWzcgfkjtVO> query =new BillQuery<AggWzcgfkjtVO>(AggWzcgfkjtVO.class);bills = query.query(pks);return PaginationUtils.filterNotExistBills(bills, pks);}//分页查询方法,查询所有PKpublic String[] pubquerypkbills(IQueryScheme queryScheme) {// String beanId=(String) queryScheme.get(QueryConstants.BEAN_ID);StringBuffer sql = new StringBuffer();QuerySchemeProcessor processor = new QuerySchemeProcessor(queryScheme);String mainAlias = processor.getMainTableAlias();sql.append(" select distinct ");sql.append(mainAlias);sql.append(".");sql.append("pk_wzcgfkjt");sql.append(processor.getFinalFromWhere());//系统当前登录用户String userId = InvocationInfoProxy.getInstance().getUserId();//根据登录用户id查询对应的人员idIUAPQueryBS bs = NCLocator.getInstance().lookup(IUAPQueryBS.class);String sql1 ="select psndoc.pk_psndoc from bd_psndoc psndoc left join sm_user smuser on smuser.pk_psndoc = psndoc.pk_psndoc where smuser.cuserid = '"+ userId + "' and nvl(psndoc.dr,0) = 0 and nvl(smuser.dr,0) = 0";String pk_psndoc = "";List<String> yhlist = new ArrayList<String>();List<String> rylist = new ArrayList<String>();try {pk_psndoc = NullValueUtils.getNullStringValue(bs.executeQuery(sql1, new ColumnProcessor()));if(!pk_psndoc.equals("")) {SqlBuilder sqlBuilder = new SqlBuilder();sqlBuilder.append("	select distinct ry.pk_psndoc, yh.cuserid	");sqlBuilder.append("	  from sm_user yh	");sqlBuilder.append("	 inner join bd_psndoc ry	");sqlBuilder.append("	    on yh.pk_psndoc = ry.pk_psndoc	");sqlBuilder.append("	   and nvl(ry.dr, 0) = 0	");sqlBuilder.append("	 where ry.def9 = '"+pk_psndoc+"'	");List<Object[]> list = (List<Object[]>) bs.executeQuery(sqlBuilder.toString(), new ArrayListProcessor());if(list != null && list.size() > 0) {for (int i = 0; i < list.size(); i++) {Object[] objs = list.get(i);yhlist.add(NullValueUtils.getNullStringValue(objs[1]));rylist.add(NullValueUtils.getNullStringValue(objs[0]));}}}} catch (BusinessException e) {ExceptionUtils.wrappBusinessException(e.getMessage());}yhlist.add(userId);rylist.add(pk_psndoc);SqlBuilder rytj = new SqlBuilder();rytj.append(" "+mainAlias+".pk_psndoc  ",rylist.toArray(new String[0]));SqlBuilder yhtj = new SqlBuilder();yhtj.append(" "+mainAlias+".creator  ",yhlist.toArray(new String[0]));//查询出制单人为当前登录人的记录(当前跟踪人为空)。
//        sql.append(" and ( " +yhtj.toString()+" ) ");DataAccessUtils dao = new DataAccessUtils();IRowSet rowset = dao.query(sql.toString());String[] keys = rowset.toOneDimensionStringArray();return keys;}}

4. WzcgfkjtMaintainImpl.java

在这里插入图片描述

package nc.impl.jych;import java.util.Arrays;
import java.util.List;import nc.impl.pub.ace.AceWzcgfkjtPubServiceImpl;
import nc.itf.jych.IWzcgfkjtMaintain;
import nc.ui.querytemplate.querytree.IQueryScheme;
import nc.vo.jych.wzcgfkjt.AggWzcgfkjtVO;
import nc.vo.pub.BusinessException;
import nc.vo.pub.CircularlyAccessibleValueObject;
import nc.vo.pub.IVOMeta;public class WzcgfkjtMaintainImpl extends AceWzcgfkjtPubServiceImpl
implements IWzcgfkjtMaintain {@Overridepublic AggWzcgfkjtVO[] queryBillByPK(String[] pks) throws BusinessException {AggWzcgfkjtVO[] pubquerybillbypkbills = super.pubquerybillbypkbills(pks);if (pubquerybillbypkbills != null && pubquerybillbypkbills.length > 0) {for (AggWzcgfkjtVO aggVO : pubquerybillbypkbills) {IVOMeta[] children = aggVO.getMetaData().getChildren();if (children != null && children.length != 0) {for (IVOMeta item : children) {CircularlyAccessibleValueObject[] childrenVO = (CircularlyAccessibleValueObject[]) aggVO.getChildren(item);
//						@SuppressWarnings("unchecked")List<CircularlyAccessibleValueObject> asList = Arrays.asList(childrenVO);
//						asList.sort((x, y) -> Double.compare(
//								x.getAttributeValue("rowno") == null ? 0
//										: new Double(x.getAttributeValue("rowno").toString()),
//								y.getAttributeValue("rowno") == null ? 0
//										: new Double(y.getAttributeValue("rowno").toString())));}}}}return super.pubquerybillbypkbills(pks);}@Overridepublic String[] queryPKs(IQueryScheme queryScheme) throws BusinessException {return super.pubquerypkbills(queryScheme);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/537842.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《系统架构设计师教程(第2版)》第6章-据库设计基础知识-03-关系数据库设计

文章目录 0. 设计的基本步骤0.1 用户需求分析0.2 概念结构设计0.3 逻辑结构设计0.4 物理结构设计0.5 数据库实施阶段0.6 数据库运行和维护阶段 1. 数据需求分析1.1 概述1.2 需要获取的需求 2. 概念结构设计2.1 概述2.2 E-R方法2.3 概念结构设计工作步骤2.3.1 选择局部应用2.3.2…

Stable Diffusion 模型下载:Juggernaut(主宰、真实、幻想)

本文收录于《AI绘画从入门到精通》专栏&#xff0c;专栏总目录&#xff1a;点这里。 文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八 下载地址 模型介绍 该模型是一个真实模型&#xff0c;并且具有幻想和创意色彩。 作者述&#xff1a;我选取了…

阿里云-云服务器ECS新手如何建网站?

租阿里云服务器一年要多少钱&#xff1f; 不同类型的服务器有不同的价格。 以ECS计算型c5为例&#xff1a;2核4G-1年518.40元&#xff0c;4核8G-1年948.00元。 阿里云ECS云服务器租赁价格由三部分组成&#xff1a; 也就是说&#xff0c;云服务器配置成本磁盘价格网络宽带价格…

MBT-Net

feature F&#xff0c;edge feature E-F where r related to the relative position 辅助信息 作者未提供代码

STC89C52单片机 启动!!!(一)

跑马灯实现 直接上代码 #include<regx52.h> sbit D1P2^0; sbit D2P2^1; sbit D3P2^2; sbit D4P2^3; sbit D5P2^4; sbit D6P2^5; sbit D7P2^6; sbit D8P2^7; void delay(int num){while(num--){} } void led_running(){//从第1盏灯到第8盏灯依次点亮D10;delay(40000);D2…

Github主页设置贪吃蛇详细教程

先看最终实现结果&#xff1a; 有条贪吃蛇放在主页还是蛮酷的哈哈哈。接下来我来讲一讲怎么在Github主页添加一条贪吃蛇。 首先要修改自己的Github的主页&#xff0c;我们得有一个特殊的仓库——这个仓库必须与你的Github用户名保持一致&#xff0c;并且需要公开&#xff0c…

Database Connection Pool 数据库连接池-01-概览

拓展阅读 第一节 从零开始手写 mybatis&#xff08;一&#xff09;MVP 版本。 第二节 从零开始手写 mybatis&#xff08;二&#xff09;mybatis interceptor 插件机制详解 第三节 从零开始手写 mybatis&#xff08;三&#xff09;jdbc pool 从零实现数据库连接池 第四节 从…

QT c++ 双精度数拆分和组合 Tool

本文描述QT c的双精度数拆分和合并&#xff0c;即双精度浮点数拆为四个16位无符号整数以及将四个16位无符号整数组合为双精度浮点数。 开发平台&#xff1a;win10QT6.2.4 MSVC2019 64 bit 在本文的最好列出了代码和可执行文件打包下载链接&#xff08;可直接使用&#xff09;…

国创证券|炒股有哪八不碰?

炒股存在以下八不碰&#xff1a; 1、散户多的个股不碰 散户较多&#xff0c;则阐明市场上的散户在不断地买入该股&#xff0c;主力在不断地卖出该股&#xff0c;筹码逐步从主力的手中流入散户的手中&#xff0c;这会引起市场上的投资者惊惧&#xff0c;大量地抛出手中的股票&…

maven打包把所有依赖的jar copy到一个文件夹

在maven项目中&#xff0c;是使用依赖坐标来引入jar包&#xff0c;在引入jar包的时候&#xff0c;maven也会默默的帮助我们导入这个jar包所依赖的jar包。 但是当我们打包项目使用jar包运行的时候&#xff0c;往往会出现缺少jar的情况&#xff1a; 如果我们一个一个添加缺少的…

Android系统 关于ntp的修改(网络时间同步)

一&#xff0c;现象&#xff1a; 1. NTP介绍 NTP&#xff1a;网络时间协议&#xff0c;英文名称&#xff1a;Network Time Protocol&#xff08;NTP&#xff09;是用来使计算机时间同步化的一种协议&#xff0c;它可以使计算机对其服务器或时钟源&#xff08;如石英钟&#x…

input输入框支持明文暗文切换

input输入框支持明文暗文切换 场景与思路实现 场景与思路 我们通常实现密码框的时候会直接使用 input ,设置它的 type 为 password&#xff0c;如果要实现明文和暗文的切换&#xff0c;实际上就是 type“text” 和 type"password"的切换。 实现 样式上我们可以先找…