目录:

创建新类(表)(class文件)与创建routine(.mac  .inc)

在类里面添加函数(classmethod)

Terminal的使用

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

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

创建新类(表)(class文件)与创建routine(.mac  .inc)

一个.cls文件对应一个.mac文件和.inc文件,属性(property)与函数(method/query)定义放在.cls文件中,具体的处理函数写入.mac文件中,常量在.inc文件中定义,将用于函数调用数组时使用的(1,2,3)定义为具体的变量名,使.mac与文件易读

File/New.../General

cache class definition(.cls)

cache objectScript routine(.mac/.int)

输入适当的包名(Package Name)和新建的类名(Class Name)如图,就能得到一个名为Package.Class.cls的类文件了,可以在workspace/project中找到该文件

新建类时,一个类对应一张表,对于该表的所有操作方法组成一个类;放在同一个包下的各个类是相关联的,在实际意义中,一个包下的类对同一个大问题的不同方面进行描述。具体的建立和分类方式通过数据库设计方式来指导,在此处不多说。

新建的文件如上图所示,代码写在大括号内

一个类(表)里的要素:

属性、主键、索引、方法。

新建属性:

直接写语句:

Property ID As %String [ Required ];

就可以新建一个名为ID的属性,该属性为字符串类型(注意区分大小写),且在表中是必需属性不能为空

也可以找到一个new property的按钮,按照新建向导新建一个属性

若表与表之间是父子表的关系,比如父表是基本信息,子表是详细信息,要在属性中建立两个表之间的联系:(下例中父表是Class1,子表是Class2,共同放在P包下)

在P.Class1.cls中的属性中需要写:

Relationship Class2 As P.Class2 [ Cardinality = children, Inverse = Class1 ];

在P.Class1.cls中的属性中需要写:

Relationship Class1 As P.Class1 [ Cardinality = parent, Inverse = Class2 ];

设置主键:

Index PK On (Pr1, Pr2) [ IdKey, PrimaryKey, Unique ];

设置索引:Query中的查找依据

Index IdxA On (Pr1, Pr2);

这里Pr1和Pr2可以是主键,也可以不是主键

与其他表连接时,即具体的属性名在另一张表里,在这张表也同时有体现:

Property RevisionInfo As Cm.RevisionInfo;

这样的意思是本张表有一组属性RevisionInfo在表Cm.RevisionInfo里,同时在本张表里也能看到这一组属性。

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

添加方法(SetData):

写方法时需要同时对(.cls.mac.inc)三个文件进行操作:

.cls文件:

ClassMethod SetData(PlanNo As %String, PatientId As %String, StartDate As %Integer, EndDate As %Integer, Module As %String, Status As %Integer, DoctorId As %String, UserId As %String, TerminalName As %String, TerminalIP As %String, DeviceType As %Integer) As %Integer
{
Set Ret = 0
Set Ret = $$SetData^Ps.Plan( PlanNo, PatientId, StartDate, EndDate, Module, Status, DoctorId, UserId, TerminalName, TerminalIP, DeviceType)
Quit Ret
}

定义classmethod名字是setdata,括号内为传入参数及类型,设置return初始值为0,然后调用routine里的SetData函数(规定调用成功返回1,在routine中设置),退出函数并返回Ret

.mac文件

#Include %occStatus
#Include Ps.Plan.Storage
#Include ChroDiseaConst
#Include Cm.RevisionInfo.Storage SetData(PlanNo, PatientId, StartDate, EndDate, Module, Status, DoctorId, UserId, TerminalName, TerminalIP, DeviceType) Public
{
Set Ret = $$$SetDataFailed
Set key = PlanNo
Set oref = ##Class("Ps.Plan").%OpenId(key)
If ($IsObject(oref) = 0)
{
Set oref = ##Class("Ps.Plan").%New()
}
If ($IsObject(oref) = 1)
{
Set oref.PlanNo = PlanNo
Set oref.PatientId = PatientId
Set oref.StartDate = StartDate
Set oref.EndDate = EndDate
Set oref.Module = Module
Set oref.Status = Status
Set oref.DoctorId = DoctorId Set RevisionInfo = $$GetNewRevisionInfo^Cm.RevisionInfo(UserId, TerminalName, TerminalIP, DeviceType)
Set oref.RevisionInfo.DateTime = $ListGet(RevisionInfo, $$$CmRevisionInfoDateTime)
Set oref.RevisionInfo.UserId = $ListGet(RevisionInfo, $$$CmRevisionInfoUserId)
Set oref.RevisionInfo.UserName = $ListGet(RevisionInfo, $$$CmRevisionInfoUserName)
Set oref.RevisionInfo.TerminalName = $ListGet(RevisionInfo, $$$CmRevisionInfoTerminalName)
Set oref.RevisionInfo.TerminalIP = $ListGet(RevisionInfo, $$$CmRevisionInfoTerminalIP)
Set oref.RevisionInfo.DeviceType = $ListGet(RevisionInfo, $$$CmRevisionInfoDeviceType) Set sc = oref.%Save()
If $$$ISOK(sc)
{
Set Ret = $$$SetDataSuccess
}
else
{
Set ErrMsg = $System.Status.GetErrorText(sc,"")
Do WriteServerLog^Cm.CommonLibrary("","",ErrMsg)
}
Kill oref
}
Quit Ret
}

这里,ChroDiseaConst设置了工程中用到的所有状态变量,如代码中的ISOK等;Ps.Plan.Storage.inc文件设置了对应这张表的各个属性的宏文件,将调用数组元素时使用的数字设置为对应变量名,使代码易读;Cm.RevisionInfo.Storage也是相同的作用

首先设置返回初始值,设置主键,若已存在则打开这个主键对应的值,否则新建;设置各个属性的值为传入的参数;判断是否成功,否则报错;最后释放缓存并返回Ret退出。

.inc文件

#Define    PsPlanD "^Ps.PlanD"

#Define    PsPlanI "^Ps.PlanI"

#Define PsPlanPatientId 2
#Define PsPlanStartDate 3
#Define PsPlanEndDate 4
#Define PsPlanModule 5
#Define PsPlanStatus 6
#Define PsPlanDoctorId 7
#Define PsPlanRevisionInfo 8

定义宏

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

添加方法(简单查表):

.cls:

ClassMethod GetPatientPlan(PlanNo As %String) As %List
{
Set Ret = ""
Set Ret = $$GetPatientPlan^Ps.Plan(PlanNo)
Quit Ret
}

输入一个参数(PlanNo)返回符合查找条件的一个列表。首先置初值为空,然后调用routine,最后返回退出。

.mac:

GetPatientPlan(PlanNo) Public
{
Set Ret = ""
Set Data = $Get(@$$$PsPlanD@(PlanNo))
If (Data '= "")
{
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 RevisionInfo = $ListGet(Data,$$$PsPlanRevisionInfo) Set DateTime = $ListGet(RevisionInfo, $$$CmRevisionInfoDateTime)
Set UserId = $ListGet(RevisionInfo, $$$CmRevisionInfoUserId)
Set UserName = $ListGet(RevisionInfo, $$$CmRevisionInfoUserName)
Set TerminalName = $ListGet(RevisionInfo, $$$CmRevisionInfoTerminalName)
Set TerminalIP = $ListGet(RevisionInfo, $$$CmRevisionInfoTerminalIP)
Set DeviceType = $ListGet(RevisionInfo, $$$CmRevisionInfoDeviceType) Set RevisionInfoRet = $ListBuild(DateTime, UserId, UserName, TerminalName, TerminalIP, DeviceType) Set Ret = $ListBuild(PatientId, StartDate, EndDate, Module, Status, DoctorId, RevisionInfoRet)
}
Quit Ret
}

同样的,先置初值,然后从D表中查找搜索条件(本例中因为用主键查找,因此不需要索引),然后设置返回的列表内容,最后build列表并返回。

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

Terminal的使用:

命令行操作,用于对数据库进行指令操作或测试写过的方法。

如测试classmethod可以输入命令

w ##class(Ps.Plan).SetData(“xx”, “yy”, …)

测试query

do TestGetPlan^Ps.Plan()

(在routine中应有对应的测试方法TestGetPlan() )

注意,首次打开需要输入用户名密码,每次打开都要更改到对应命名空间:

zn “namespace”

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

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

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

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

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

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

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

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

    目录 Query函数及其测试 重建索引表 Management portal简介 远程访问Ensemble ============================================== ...

  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. iOS 数组内中英文混合排序

    NSInteger sortObjects(id obj1, id obj2,void *context) { NSMutableString * str1 = [[NSMutableString a ...

  2. substr mb_substr mbstrct 的用法区别

    1.substr遇到中文会出问题,用于截取英文字符 2.mb_substr() 按字符截取字符串,需要开启php_mbstring.dll <?php echo mb_substr(, , 'u ...

  3. 《奥威Power-BI智能分析报告制作方法 》精彩回顾

     上次课我们简单介绍了奥威Power-BI的智能分析报告,并展示了报告与图表相结合的应用场景.图文分析报表的意义不只在于美观,更重要的是固定框架下的灵活性和追根究底的动态分析,有着很强的实用性.上节课 ...

  4. Tomcat6.0+Jdk1.5+Axis1.3搭建java webservice环境,并使用c#调用该服务。

    java jdk:jdk1.5.0_17 下载网址:http://pan.baidu.com/s/1gdmAkgV tomcat 6.0 下载地址:http://tomcat.apache.org/d ...

  5. Unity基于响应式编程(Reactive programming)入门

    系列目录 [Unity3D基础]让物体动起来①--基于UGUI的鼠标点击移动 [Unity3D基础]让物体动起来②--UGUI鼠标点击逐帧移动 时光煮雨 Unity3D让物体动起来③—UGUI DoT ...

  6. 【翻译】hololens入门

      欢迎!我们很高兴您发现这里并做好了全息投影奇幻之旅的准备.本页面的全部内容都经由我们的工程师团队精心打造,因此这会让人觉得本页面是由软件工程师制作(别忘了,我们是全息投影技术的缔造者,而不是网页制 ...

  7. java基本数据类型包装类

    Java语言是一个面向对象的语言,但是Java中的基本数据类型却是不面向对象的,这在实际使用时存在很多的不便,为了解决这个不足,在设计类时为每个基本数据类型设计了一个对应的类进行代表,这样八个和基本数 ...

  8. 二叉树JAVA实现

    为了克服对树结构编程的畏惧感和神秘感,下定决心将二叉树的大部分操作实现一遍,并希望能够掌握二叉树编程的一些常用技术和技巧.关于编程实现中的心得和总结,敬请期待!~ [1]  数据结构和表示: 二叉树的 ...

  9. TextView,EditText中添加不同颜色的文字

    在很多时候,在我们项目里需要用到在一个TextView中要显示不同颜色的文字 private Spanned colorText(String text) { return Html.fromHtml ...

  10. mongoDB windows安装

    http://www.mongodb.org/ mongodb的官方文档. http://www.cnblogs.com/lipan/archive/2011/03/08/1966463.html  ...