zoukankan      html  css  js  c++  java
  • Domion OA 日记

      我现在使用的是IBM的 Lotus Dimion 8.5

       以下内容是个人的浅显了解,在此记录下,已作为后续记录的翻看

      第一次接触文档型数据库,确实颠覆了我对数据模型的认知,我之前一直用sql的

      文档型数据库与关系型数据库的对比:

          文档型数据库       关系型数据库     

         数据库文件          数据库                 

         表单                   表               

         文档               一条记录      

         域                     字段  

      Domion分为3大部分: 用一个模块的数据库举例

          1.表单 :表单分为主表单和子表单,一个主流程表单可能由多个子表单组成,主表单类似模板,里面存一些公用的信息,

               子表单实现具体的功能,所以如果在主表单里面看到 <计算的值>  就是嵌套的子表单,在前端界面如果想找当前页面对应的数据库以及Form,

        可以右键看属性,看在哪个 Form里面,以此来定位问题   表单上的按钮是在一个通用的子表单里面,按钮的js事件大概都是在这个里面写的

           表单可以直接从视图里面取值: 域值的取值是:

          @DbLookup 返回表的一列中通过关键字匹配选定的值。

          name:=@DbLookup(class : "NoCache" ; "" : 数据库; "视图";关键字;视图的第几列);
          @If(@IsError(name);"";name)

        

      

            2。代理(Agent):代理是表单和数据的一个中间处理环节,表单里面可以直接调用代理,调用方法有在页面加载时 主表单的WebQueryOpen

        输入执行代理 @Command([ToolsRunMacro]; "代理名称");  还有一种就是通过js 调用 代码如下:     

    var xmlhttp;
    function GetInfo(){
         var thisFrm = document.forms[0];
    	xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
       
    	xmlhttp.onreadystatechange = SetInfo;
           //调用代理的方式:
    	xmlhttp.open("Post", "/oadata/数据库名.nsf/代理名?openagent", true);
    	xmlhttp.send();
    
    }
    
    function SetInfo(){
    	var thisFrm = document.forms[0];
    	if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
    	   var xmlDoc = xmlhttp.responseXML.documentElement;
    	   alert(xmlDoc.xml);
          }
    }
    

       代理的类型有多种:常用的LotusScript 、公式、简单操作、java、引入的java(因为接触的LotusScript较多,所以就说或LotusScript)

           LotusScript 是纯vb的语法,(相当于类)Initialize 初始化加载方法  ,可直接调用Script下面的LotusScript   (需要引用:Use "类名") 

                  Script下面可写通用的类方法, 在当前操作的数据库里面可以直接得到当前操作的表单的数据   (以下代码列示)   

            Dim session As NotesSession
    	Set session = New NotesSession
    	Dim doc As NotesDocument
    	Set doc = session.DocumentContext
    	Dim db As NotesDatabase 
    	Set db = session.CurrentDatabase     
            Dim depdb As NotesDatabase 
            Dim personview As NotesView
    	Dim persondoc As notesdocument
    
            'doc  就得到了当前操作的文档的所有域的内容
        
            'doc.域的名称得到值
    
          
           '如果是想得到其它数据库里面的数据 
           ’先连接上数据库
           Set depdb=session.Getdatabase(db.Server, "oadataAIS_Org.nsf")
           '根据数据库查询它的视图
            Set personview=depdb.getview("视图名")
           ’根据源文档的信息从当前视图里面查询 注意:以上视图名的第一列一定是这个Key列才能查询到 
           Set persondoc=personview.Getdocumentbykey(“Key”, True)
    
           '然后就可以对persondoc.列名 得到想要的值
    

       3.视图(View)

         Domion  OA的数据查询都是根据视图作为查询的数据源,视图里面可以定义改数据内容 :

    SELECT form="mainform"  & sys_SuperUserdeal != "1" & sys_SoftDelete != "1"

           mainform 表名  是该数据库里面所有表单的记录  ! & 后面跟的是条件,类似与where 后面的列条件 以上就可以定义一个视图,

          视图里面有此表单里面的所有域的值(相当于是物理表里面的列)

     以上作为一个初学者还可以看看,希望有大牛可以知道纠错!

  • 相关阅读:
    软件的命名方式
    游戏软件的发展和特点
    第一章 【概论】练习与讨论 第二题
    进行博客博文管理的设计
    可视化编程是否会慢慢取代目前的主流编程
    第二次作业(软件工作量的估记方法)
    第一次作业
    string字符串格式化成time_t,并计算2个time_t的时间差
    CSV简单解析与排序输出
    jqchart总结
  • 原文地址:https://www.cnblogs.com/wanglinglong/p/5073214.html
Copyright © 2011-2022 走看看