You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
2.0 KiB
Java

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

package weaver.formmode.customjavacode.customsearch;
import java.util.*;
import weaver.conn.RecordSet;
import weaver.general.BaseBean;
import weaver.general.Util;
import weaver.hrm.User;
import weaver.formmode.customjavacode.AbstractCustomSqlConditionJavaCode;
import weaver.hrm.company.SubCompanyComInfo;
/**
* 说明
* 修改时
* 类名要与文件名保持一致
* class文件存放位置与路径保持一致。
* 请把编译后的class文件放在对应的目录中才能生效
* 注意 同一路径下java名不能相同。
* @author Administrator
*
*/
public class CustomDocSearch extends AbstractCustomSqlConditionJavaCode {
/**
* 生成SQL查询限制条件
* @param param
* param包含(但不限于)以下数据
* user 当前用户
*
* @return
* 返回的查询限制条件的格式举例为: t1.a = '1' and t1.b = '3' and t1.c like '%22%'
* 其中t1为表单主表表名的别名
*/
public String generateSqlCondition(Map<String, Object> param) throws Exception {
BaseBean bb = new BaseBean();
String showcompid = Util.null2String(bb.getPropValue("tgzz","showcompid"));
SubCompanyComInfo subcom = new SubCompanyComInfo();
List ll = subcom.getSubCompanyIdList(522);
System.out.println("ll=========="+ll.size()+"====="+ll.get(0));
System.out.println("docquery=========="+param);
System.out.println(param);
User user = (User)param.get("user");
String subcomid = (String) param.get("subcomid");
String deptid = (String) param.get("deptid");
System.out.println("subcomid===="+subcomid+"===deptid==="+deptid);
String sqlCondition = "";
if(subcomid!=null && !"".equals(subcomid)){
// sqlCondition = "t1.fb="+subcomid;
sqlCondition = "(t1.fb in (select id from hrmsubcompany where supsubcomid="+subcomid+") or t1.fb ="+subcomid+")";
}
if(deptid!=null && !"".equals(deptid)){
// sqlCondition = "t1.bzbm="+deptid;
sqlCondition = "(t1.bzbm in (select id from hrmdepartment where supdepid ="+deptid+") or t1.bzbm="+deptid+")";
}
return sqlCondition;
}
}