我现在使用的是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 后面的列条件 以上就可以定义一个视图,
视图里面有此表单里面的所有域的值(相当于是物理表里面的列)
以上作为一个初学者还可以看看,希望有大牛可以知道纠错!