目录

Query函数及其测试

重建索引表

Management portal简介

远程访问Ensemble

===================================================

===================================================

Query函数及其测试:

query工作原理:

.cls部分:

首先根据query传入数据建立索引表IdxA(需要在portal里build)声明query时设置函数名、传入变量和传出变量列表包含三个classmethod: Execute, Fetch, Close

Execute设置查找数据时的依据,包含全部主键及索引,存入qHandle数组里

Fetch为主体,传入查找依据(qHandle), Row(需要得到的列表), AtEnd(0可以进行下去,1终止)

设置初始值:AtEnd = 1(若后面查找不到数据则终止), Row为空,查找依据数组设置回变量方便写函数,调用Routine,将返回值赋给各个变量,为下一次循环准备

Query GetPlan(Status As %Integer, StartDate As %Integer) As %Query(ROWSPEC = "PlanNo:%String,PatientId:%String,StartDate:%Integer,EndDate:%Integer,Module:%String,Status:%Integer,DoctorId:%String") [ SqlProc ]
{
} ClassMethod GetPlanExecute(ByRef qHandle As %Binary, Status As %Integer, StartDate As %Integer) As %Status
{
Set qHandle(0) = "" ;PlanNo
Set qHandle(1) = StartDate
Set qHandle(2) = Status
Quit $$$OK
} ClassMethod GetPlanClose(ByRef qHandle As %Binary) As %Status [ PlaceAfter = GetPlanExecute ]
{
Kill qHandle
Quit $$$OK
} ClassMethod GetPlanFetch(ByRef qHandle As %Binary, ByRef Row As %List, ByRef AtEnd As %Integer = 0) As %Status [ PlaceAfter = GetPlanExecute ]
{
Set AtEnd = 1
Set Row = ""
Set PlanNo = qHandle(0)
Set StartDate = qHandle(1)
Set Status = qHandle(2)
Set Data = $$GetPlan^Ps.Plan(PlanNo, StartDate, Status)
Set AtEnd = $ListGet(Data,1)
Set Row = $ListGet(Data,2)
Set qHandle(0) = $ListGet(Data,3)
Set qHandle(1) = $ListGet(Data,4)
Set qHandle(2) = $ListGet(Data,5)
Quit $$$OK
}

.mac文件部分:

query逻辑:

启动:传入StartDate和Status,PlanNo为空,根据Status和IdxA由后向前找到第一条数据的StartDate进入while循环:目的是在不传出有效数据的情况下不必跳出Fetch

过程:判断StartDate是否符合条件,若不符合跳出并终止Fetch根据IdxA, Status, StartDate找到一条数据并设定PlanNo判断PlanNo不为空的时候,进行查找和传出数据;否则按照之前的方法查找下一条数据并再次进入循环传出AtEnd值(0可以继续进入Fetch,1终止Fetch), Row(返回的列表), PlanNo, Status, StartDate根据这三者查找下一条数据

GetPlan(PlanNo, StartDate, Status) Public
{ If (PlanNo '= "")
{
Goto Next
} // -1表示从后向前查找,因为该函数的目的是找时间最近的,因此从后向前查找会避免很多问题
Set StartDate = $Order(@$$$PsPlanI@("IdxA", Status, StartDate), -1) While (StartDate '= "")
{ If (StartDate <)
{
Goto Exit
} Next
Set PlanNo = $Order(@$$$PsPlanI@("IdxA", Status, StartDate, PlanNo), -1)
If (PlanNo '= "")
{
Set Data = $Get(@$$$PsPlanD@(PlanNo))
Set PatientId = $ListGet(Data, $$$PsPlanPatientId)
Set StartDate = $ListGet(Data, $$$PsPlanStartDate)
Set EndDate = $ListGet(Data, $$$PsPlanEndDate)
Set Module = $ListGet(Data, $$$PsPlanModule)
Set Status = $ListGet(Data, $$$PsPlanStatus)
Set DoctorId = $ListGet(Data, $$$PsPlanDoctorId) Set Row = $ListBuild(PlanNo, PatientId, StartDate, EndDate, Module, Status, DoctorId) Set AtEnd = 0
Goto Exit
} Set StartDate = $Order(@$$$PsPlanI@("IdxA", Status, StartDate), -1)
} Exit
Set Ret = $ListBuild(AtEnd, Row, PlanNo, StartDate, Status)
Quit Ret
}

Query 的测试方法写在routine中,

// do TestGetPlan^Ps.Plan()
TestGetPlan() Public
{
Set rs = ##Class(%ResultSet).%New("Ps.Plan:GetPlan")
do rs.Execute(4, 20160926)
While rs.Next()
{
w " PlanNo"_rs.GetData(1)_" StartDate"_rs.GetData(3)_" Status"_rs.GetData(6),!
}
do rs.Close()
Kill rs
Quit
}

需要注意的是,非主键的属性作为索引时,在I表里小写会自动转成大写;非必需的属性作为索引,在I表里会自动在前面加一个空格。这里我自己的推测是在索引时,非必需的属性可能为空,而在routine中,是要根据这个属性进行索引的,为防止可能为空的数据无法被索引到,会自动在前面加一个空格。因此在写query的routine时,要注意在编码时加空格匹配;在test时,要注意大小写和空格的问题。

===================================================

重建索引表:

正常输入数据后,数据存放在D表中,而query在查找数据时,会使用索引表(I表)。I表是根据D表和cls文件中的设置建立起来的

Management portal/system explorer/SQL

更改命名空间,打开左侧的Tables下拉栏,找到需要重建的表名

在右侧可以看到基本信息,找到上面的Action/rebuild indices即可建立I表

另外open table可以查看当前表的所有内容,在当前页的最下方可以调节显示数据的条数

==========================================================

Management portal简介:

除了上述的System Explorer/SQL外,常用的还有System Explorer/Globals用于导入导出数据和查看表格;System Operation进行配置;System Administration进行管理等

==========================================================

远程访问Ensemble:

首先关闭防火墙才能被其他服务器远程访问。

访问其他服务器时,首先进行配置。

左键右下角图标,Prefered Server/AddEdit…

Localhost这一行可以看到自己的Port/Web Server Port配置情况,点击Add添加其他服务器IP地址、端口和网络端口保存

再查看prefered server即可看到当前的首选服务器,在remote system access里可以打开任意可以远程到的服务器的studio/terminal/management portal/documentation

Caché数据库学习笔记(3)的更多相关文章

  1. Caché数据库学习笔记(1)

    目录: Caché的概念和基础知识 Caché数据库的安装 创建命名空间(namespace)和数据库(database) Documentation的使用 ===================== ...

  2. Caché数据库学习笔记(5)

    目录 Cache数据库方法的RESTful封装 ================================================================ 因为对web serv ...

  3. Caché数据库学习笔记(4)

    目录 DeepSee的使用 数据.方法等的导入与导出 ======================================================== ================ ...

  4. Caché数据库学习笔记(2)

    目录: 创建新类(表)(class文件)与创建routine(.mac  .inc) 在类里面添加函数(classmethod) Terminal的使用 ======================= ...

  5. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  6. MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  7. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  8. Mysql数据库学习笔记之数据库索引(index)

    什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...

  9. MYSQL数据库学习笔记1

      MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...

随机推荐

  1. C语言 ---- 基本数据类型和基本运算 iOS学习-----细碎知识点总结

    // 导入头文件(stdio.h),标准输入输出的头文件,#include <stdio.h> // 程序的入口int main(int argc, const char * argv[] ...

  2. Python之路-python(面向对象一)

    一.面向对象介绍 二.为什么要用面向对象开发 三.封装.继承.多态.类.方法 面向过程和面向对象的区别 编程范式: 一般情况下,拿到一个项目不同的两个人有不同的编写方式(相同的是固定的语法.数据结构) ...

  3. MSSQL 2012 拒绝了对对象 'extended_properties' (数据库 'mssqlsystemresource',架构 'sys')的 SELECT 权限

    查看数据库的表的时候报如下错误: MSSQL 拒绝了对对象 ) 解决方法: 在数据库里相应的用户权限中,把db_denydatareader的复选框的勾去掉.db_denydatareader是拒绝访 ...

  4. 跨域解决方案一:使用CORS实现跨域

    跨站HTTP请求(Cross-site HTTP request)是指发起请求的资源所在域不同于请求指向的资源所在域的HTTP请求. 比如说,我在Web网站A(www.a.com)中通过<img ...

  5. AngularJS安装配置与基础概要整理(上)

    以前整理的,可供参考. 安装: 1.首先要安装node.js和它的npm包管理系统.(nodejs相关待整理) 2.安装grunt .grunt是一个基于任务的Javascript工程命令行构建工具. ...

  6. C语言之memcpy函数

    昨天自己动手实现memcpy这个函数,用一个例程试了一下,结果正确,满心欢心,可是有些地方想不明白,于是百度了一下,结果自己写的函数简直无法直视. 觉得还是写个总结,以示教训. 先贴上我自己的函数: ...

  7. Leetcode: Battleships in a Board

    Given an 2D board, count how many different battleships are in it. The battleships are represented w ...

  8. java入门之从C#快速入门java

    可变参数: Void sum(int…list){}以“…”三个字为关键字 可变参数:以params为关键字 34 对异常的描述: java中,异常分为两种,运行时异常(也就是uncheckExcep ...

  9. Prism 5 + MEF中的ModuleCatalog.CreateFromXaml问题

    protected override IModuleCatalog CreateModuleCatalog() { return Microsoft.Practices.Prism.Modularit ...

  10. flask学习资源

    1.flask快速入门(视频) http://www.pythoner.cn/course/topic/flask-web-development/ 2.flask教程,开源中国 http://www ...