windchill开发简单入门之高级条件查询

源:原创 作者:云淡天晴 时间:2008-10-17

       在上一篇文章中,我们介绍了windchill开发简单入门之条件查询,可以说是查询中必备的能力。但是现实中,我们的查询将更加复杂,我们平时能够进行sql语句的多表查询,那么windchill本身是不是也有这样的简单但是方便功能强大的查询呢?答案是肯定的,但是相关资料比较少,或者说也比较复杂,在这里,我们对此举一个实例。

   以下是我们的源代码:

 import wt.clients.prodmgmt.WTPartHelper;
import wt.fc.PersistenceHelper;
import wt.fc.QueryResult;
import wt.part.WTPart;
import wt.part.WTPartMaster;
import wt.part.WTPartUsageLink;
import wt.query.CompositeWhereExpression;
import wt.query.ConstantExpression;
import wt.query.LogicalOperator;
import wt.query.QueryException;
import wt.query.QuerySpec;
import wt.query.SearchCondition;
import wt.query.TableColumn;
import wt.util.WTException;


public class Demo3
{

 /**
  * @param args
  * @throws WTException
  */
 public static void main(String[] args) throws WTException
 {
  // 这里在本机windchill系统中查询固定编码的part
  WTPart[] parts=WTPartHelper.findPartByNumber("0000000001");
  WTPart[] parts2=WTPartHelper.findPartByNumber("0000000002");
  WTPartMaster master=null;
  if(parts2[0]!=null)
  {
   //获取该part对应的WTPartMaster
      master=(WTPartMaster)parts2[0].getMaster();
  }
  WTPartUsageLink link=queryPartusageLink(parts[1], master);
  System.out.println("WTPartUsageLink:"+link);
 }
 
 /**
  * 查询part与另一个part是否已经有WTPartUsageLink的关系
  * @param part   父节点
  * @param master  子节点
  * @return  
  */
 public static WTPartUsageLink queryPartusageLink(WTPart part, WTPartMaster master)
 {
  //如果part或者master任一为空,则返回空值
  if (part == null || master == null)
  {
   return null;
  }
  long poid = part.getPersistInfo().getObjectIdentifier().getId();
  long moid = master.getPersistInfo().getObjectIdentifier().getId();
  try
  {
   QuerySpec queryspec = new QuerySpec();
   //该关系的类是WTPartUsageLink
   int a = queryspec.appendClassList(WTPartUsageLink.class, true);
   //此处一定要设置为true,通知系统为高级查询
   queryspec.setAdvancedQueryEnabled(true);
   String[] aliases = new String[1];
   aliases[0] = queryspec.getFromClause().getAliasAt(a);
   //IDA3A5为数据表中字段,存贮的就是part的id
   TableColumn tc1 = new TableColumn(aliases[0], "IDA3A5");
   //IDA3B5为数据表中字段,存贮的就是master的id
   TableColumn tc2 = new TableColumn(aliases[0], "IDA3B5");
   //此处查询的sql语句是与的关系
   CompositeWhereExpression andExpression = new CompositeWhereExpression(LogicalOperator.AND);
   //设置条件
   andExpression.append(new SearchCondition(tc1, "=", new ConstantExpression(new Long(poid))));
   andExpression.append(new SearchCondition(tc2, "=", new ConstantExpression(new Long(moid))));
   queryspec.appendWhere(andExpression, null);
   QueryResult qr1 = PersistenceHelper.manager.find(queryspec);
   if (qr1.hasMoreElements())
   {
    Object obj[] = (Object[]) qr1.nextElement();
    WTPartUsageLink usage = (WTPartUsageLink) obj[0];
    return usage;
   }
  }
  catch (QueryException e)
  {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  catch (WTException e)
  {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  return null;
 }
 
}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Windchill是PTC公司一款用于产品生命周期管理(PLM)的软件平台。二次开发是指在Windchill平台上使用软件开发技术进行定制化开发,以满足企业特定的业务需求。 想要进行Windchill二次开发入门,首先需要掌握Java编程语言。Java是Windchill平台主要的开发语言,熟练掌握Java编程可以帮助我们在Windchill平台上进行二次开发。 其次,我们需要熟悉Windchill平台的架构和数据模型。了解Windchill的架构可以帮助我们理解软件的运行机制,以及如何通过二次开发来扩展和定制Windchill的功能。同时,熟悉Windchill的数据模型可以帮助我们理解数据在Windchill平台中的组织和管理方式,为二次开发提供基础。 在掌握基本的Java编程和Windchill平台的知识后,我们可以开始进行实际的二次开发工作。在二次开发中,我们可以利用Windchill提供的API(应用程序接口)来访问和操作Windchill平台的各种功能和数据。通过API,我们可以实现自定义的业务逻辑和界面,满足企业特定的需求。 最后,为了更好地进行Windchill二次开发,我们还可以参考相关的文档和教程。PTC公司为Windchill开发者提供了丰富的文档资源,包括开发手册、API文档等,可以帮助我们更好地理解Windchill的二次开发方式和最佳实践。 总之,想要进行Windchill二次开发入门,需要掌握Java编程语言,熟悉Windchill平台的架构和数据模型,并借助Windchill提供的API进行实际的开发工作。不断学习和实践,我们可以逐渐提升自己的二次开发能力,并为企业定制出更符合需求的Windchill应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值