分享过滤条件中增加一个自定义过滤变量插件代码
来源:互联网 发布:javascript:void(0); 编辑:程序博客网 时间:2024/05/16 00:54
// 以下代码示例演示过滤条件中增加一个自定义过滤变量,例如预算部门// 另外还需要在t_mdl_filtercondition,t_mdl_filtercondition_l中增加相应记录,例如/*--插入配置过滤条件<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />DELETE FROM T_MDL_FILTERCONDITION WHERE FID=1000001;INSERT INTO T_MDL_FILTERCONDITION(FID,FCONDITIONTYPEID,FSEQ,FOPERATE,FINPUTCTLTYPE,FDATASOURCETYPE,FDATAFIELDINDEX,FVALUE,FINPUT,FCLASSNAME) VALUES (1000001, 1000001,1,'=',0,0,0,'ISNULL',0,'XXApp.Core.BuggetDeptFilter.CurrBuggetDeptFilter,XXApp.Core') ;--插入配置过滤条件多语言DELETE FROM T_MDL_FILTERCONDITION_L WHERE FID=1000001;INSERT INTO T_MDL_FILTERCONDITION_L(FPKID,FID,FLOCALEID,FNAME,FDATASOURCE,FTOOLTIP) VALUES (1000001,1000001,2052,N'当前预算部门',null,null) ;*/using System;using System.Collections.Generic;using System.Linq;using System.Text;using Kingdee.BOS.Core.CommonFilter.ConditionVariableAnalysis;using Kingdee.BOS.Core.CommonFilter;using System.ComponentModel;using Kingdee.BOS.App.Data;namespace XXApp.Core.BuggetDeptFilter{/// <summary>/// 当前用户根据预算部门进行过滤/// </summary>[Description("当前用户根据预算部门进行过滤")]public class CurrBuggetDeptFilter : AbstractVariableAnalysisPlugin {public override string GetVariableFilter(ConditionVariableContext ctx){StringBuilder sb = new StringBuilder();// 获取当前登录用户所在的部门sb.AppendFormat("select staff.FDEPTID ");sb.AppendFormat(" from t_bd_staff staff ");sb.AppendFormat(" inner join t_sec_user suser on staff.fpersonid=suser.FLINKOBJECT ");sb.AppendFormat(" inner join V_BD_CONTACTOBJECT vcon on vcon.fid=suser.FLINKOBJECT and vcon.ftype=1 ");sb.AppendFormat(" where suser.fuserid={0} ", ctx.Context.UserId);// 获取部门对应的预算部门内码string strSelect = string.Format(@"select fdeptidfrom t_bd_department where fdeptid IN ({0}) and FISBUDGET=1union allselect FBudgetDeptfrom t_bd_department where fdeptid IN ({0}) and FISBUDGET=0", sb.ToString());long currDeptId = DBUtils.ExecuteScalar<long>(ctx.Context, strSelect, 0, null);// 当前用户没有关联职员if (currDeptId <= 0){return "1=1";}// 取出当前预算部门的名称string strSql = string.Format(@"SELECT FNAME FROM T_BD_DEPARTMENT_L WHERE FDEPTID={0} AND FLOCALEID={1}", currDeptId, ctx.Context.UserLocale.LCID);string strName = DBUtils.ExecuteScalar<string>(ctx.Context, strSql, string.Empty, null);return string.Format("{0} {1} '{2}'", ctx.FieldName , ctx.Operater, strName);}}}
0 0
- 分享过滤条件中增加一个自定义过滤变量插件代码
- 列表界面增加自定义面板过滤条件
- 自定义过滤条件
- 代码实现listUI界面增加新条件过滤
- Android EditText 增加自定义过滤
- grep过滤满足两个条件中一个的行
- 【变量过滤】防止代码注入
- AngualrJS 代码中过滤
- 自定义过滤条件的实现方法(1)
- 自定义 Azure Table storage 查询过滤条件
- 在MAXIMO5.2中为模块的main.jsp增加过滤条件
- 给产品增加一个过滤属性test
- ibatis增加任意组合字符串和过滤条件
- 即时报表中使用专项过滤条件
- 在sphinx中应用复杂过滤条件
- Oracle 中按条件过滤重复记录
- php中过滤字符串代码
- idea中提交过滤代码
- Html5 FileReader实现即时上传图片功能
- ios开发(六)
- redis配置文件redis.conf详细说明
- android 图片裁剪
- Android主线程、子线程通信(Thread+handler)
- 分享过滤条件中增加一个自定义过滤变量插件代码
- Eclipse 工程常见问题
- IntelliSense: #error 指令: Please use the /MD switch for _AFXDLL builds解决办法
- windos批处理中的变量
- ffmpeg 打包TS介绍
- Linux下正确安装VMWARE TOOLS
- VS2008 MFC中常出现的几个问题
- 用Dev-Cpp搭建MySQL++编程环境
- zoj 3669 Japanese Mahjong I