| 1 | DINIT2A5 ;SFISC/MKO-KEY AND INDEX FILES ;10:50 AM  30 Mar 1999 | 
|---|
| 2 | ;;22.0;VA FileMan;;Mar 30, 1999 | 
|---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | F I=1:2 S X=$T(Q+I) Q:X=""  S Y=$E($T(Q+I+1),4,999),X=$E(X,4,999) S:$A(Y)=126 I=I+1,Y=$E(Y,2,999)_$E($T(Q+I+1),5,99) S:$A(Y)=61 Y=$E(Y,2,999) S @X=Y | 
|---|
| 5 | G ^DINIT2A6 | 
|---|
| 6 | Q Q | 
|---|
| 7 | ;;^DIC(.31,0,"GL") | 
|---|
| 8 | ;;=^DD("KEY", | 
|---|
| 9 | ;;^DIC("B","KEY",.31) | 
|---|
| 10 | ;;= | 
|---|
| 11 | ;;^DIC(.31,"%D",0) | 
|---|
| 12 | ;;=^^12^12^2980911^ | 
|---|
| 13 | ;;^DIC(.31,"%D",1,0) | 
|---|
| 14 | ;;=This file stores information about keys on a file or subfile. A key is a | 
|---|
| 15 | ;;^DIC(.31,"%D",2,0) | 
|---|
| 16 | ;;=set of one or more fields that uniquely identifies a record in a file. If | 
|---|
| 17 | ;;^DIC(.31,"%D",3,0) | 
|---|
| 18 | ;;=more than one set of fields can uniquely identify a record, one of those | 
|---|
| 19 | ;;^DIC(.31,"%D",4,0) | 
|---|
| 20 | ;;=sets should be designated the primary key; all others should be designated | 
|---|
| 21 | ;;^DIC(.31,"%D",5,0) | 
|---|
| 22 | ;;=secondary keys. The primary key is the principal means of identifying | 
|---|
| 23 | ;;^DIC(.31,"%D",6,0) | 
|---|
| 24 | ;;=records in the file. | 
|---|
| 25 | ;;^DIC(.31,"%D",7,0) | 
|---|
| 26 | ;;= | 
|---|
| 27 | ;;^DIC(.31,"%D",8,0) | 
|---|
| 28 | ;;=To allow FileMan to enforce key uniqueness, the database designer must | 
|---|
| 29 | ;;^DIC(.31,"%D",9,0) | 
|---|
| 30 | ;;=define a regular index that consists of all the fields that make up the | 
|---|
| 31 | ;;^DIC(.31,"%D",10,0) | 
|---|
| 32 | ;;=key. This index is called the uniqueness index. | 
|---|
| 33 | ;;^DIC(.31,"%D",11,0) | 
|---|
| 34 | ;;= | 
|---|
| 35 | ;;^DIC(.31,"%D",12,0) | 
|---|
| 36 | ;;=All key fields must have values. They cannot be null. | 
|---|
| 37 | ;;^DD(.31,0) | 
|---|
| 38 | ;;=FIELD^^3^5 | 
|---|
| 39 | ;;^DD(.31,0,"DDA") | 
|---|
| 40 | ;;=N | 
|---|
| 41 | ;;^DD(.31,0,"DT") | 
|---|
| 42 | ;;=2980611 | 
|---|
| 43 | ;;^DD(.31,0,"IX","B",.31,.01) | 
|---|
| 44 | ;;= | 
|---|
| 45 | ;;^DD(.31,0,"NM","KEY") | 
|---|
| 46 | ;;= | 
|---|
| 47 | ;;^DD(.31,.01,0) | 
|---|
| 48 | ;;=FILE^RNJ20,7^^0;1^K:+X'=X!(X>999999999999)!(X<0)!(X?.E1"."8N.N) X | 
|---|
| 49 | ;;^DD(.31,.01,1,0) | 
|---|
| 50 | ;;=^.1^^-1 | 
|---|
| 51 | ;;^DD(.31,.01,1,1,0) | 
|---|
| 52 | ;;=.31^B | 
|---|
| 53 | ;;^DD(.31,.01,1,1,1) | 
|---|
| 54 | ;;=S ^DD("KEY","B",$E(X,1,30),DA)="" | 
|---|
| 55 | ;;^DD(.31,.01,1,1,2) | 
|---|
| 56 | ;;=K ^DD("KEY","B",$E(X,1,30),DA) | 
|---|
| 57 | ;;^DD(.31,.01,1,1,3) | 
|---|
| 58 | ;;=Lets developers pick keys by their file number | 
|---|
| 59 | ;;^DD(.31,.01,1,1,"%D",0) | 
|---|
| 60 | ;;=^^2^2^2980911^^ | 
|---|
| 61 | ;;^DD(.31,.01,1,1,"%D",1,0) | 
|---|
| 62 | ;;=The B index on the .01 (File) of the Key file lets developers pick keys by | 
|---|
| 63 | ;;^DD(.31,.01,1,1,"%D",2,0) | 
|---|
| 64 | ;;=the file whose records they uniquely distinguish. | 
|---|
| 65 | ;;^DD(.31,.01,3) | 
|---|
| 66 | ;;=Type a Number between 0 and 999999999999, 7 Decimal Digits. Answer '??' for more help. | 
|---|
| 67 | ;;^DD(.31,.01,4) | 
|---|
| 68 | ;;= | 
|---|
| 69 | ;;^DD(.31,.01,21,0) | 
|---|
| 70 | ;;=^^2^2^2980908^ | 
|---|
| 71 | ;;^DD(.31,.01,21,1,0) | 
|---|
| 72 | ;;=Answer should be the number of the file or subfile identified by this key. | 
|---|
| 73 | ;;^DD(.31,.01,21,2,0) | 
|---|
| 74 | ;;=A file may have more than one key, but only one primary key. | 
|---|
| 75 | ;;^DD(.31,.01,"DT") | 
|---|
| 76 | ;;=2980611 | 
|---|
| 77 | ;;^DD(.31,.02,0) | 
|---|
| 78 | ;;=NAME^RF^^0;2^K:$L(X)>1!($L(X)<1)!'(X?1U) X | 
|---|
| 79 | ;;^DD(.31,.02,3) | 
|---|
| 80 | ;;=Answer must be 1 upper case letter. Answer '??' for more help. | 
|---|
| 81 | ;;^DD(.31,.02,4) | 
|---|
| 82 | ;;= | 
|---|
| 83 | ;;^DD(.31,.02,21,0) | 
|---|
| 84 | ;;=^^3^3^2980908^^ | 
|---|
| 85 | ;;^DD(.31,.02,21,1,0) | 
|---|
| 86 | ;;=Answer must be the name of this key. The name of a file's primary key | 
|---|
| 87 | ;;^DD(.31,.02,21,2,0) | 
|---|
| 88 | ;;=should be A, with subsequent keys for the same file named B, C, and so | 
|---|
| 89 | ;;^DD(.31,.02,21,3,0) | 
|---|
| 90 | ;;=on. | 
|---|
| 91 | ;;^DD(.31,.02,"DT") | 
|---|
| 92 | ;;=2960122 | 
|---|
| 93 | ;;^DD(.31,1,0) | 
|---|
| 94 | ;;=PRIORITY^RS^P:PRIMARY;S:SECONDARY;^0;3^Q | 
|---|
| 95 | ;;^DD(.31,1,3) | 
|---|
| 96 | ;;=Answer '??' for more help. | 
|---|
| 97 | ;;^DD(.31,1,21,0) | 
|---|
| 98 | ;;=^^2^2^2980911^ | 
|---|
| 99 | ;;^DD(.31,1,21,1,0) | 
|---|
| 100 | ;;=Answer 'PRIMARY' if this is the primary key of the file, the key that will | 
|---|
| 101 | ;;^DD(.31,1,21,2,0) | 
|---|
| 102 | ;;=usually be used for identifying entries. Otherwise, answer 'SECONDARY'. | 
|---|
| 103 | ;;^DD(.31,1,"DT") | 
|---|
| 104 | ;;=2970725 | 
|---|
| 105 | ;;^DD(.31,2,0) | 
|---|
| 106 | ;;=FIELD^.312IA^^2;0 | 
|---|
| 107 | ;;^DD(.31,2,"DT") | 
|---|
| 108 | ;;=2980310 | 
|---|
| 109 | ;;^DD(.31,3,0) | 
|---|
| 110 | ;;=UNIQUENESS INDEX^*P.11'^DD("IX",^0;4^S DIC("S")="I 1 Q:'$D(DDS)!'$D(DIKKEY)  I $P(^(0),U,9)=$P(^DD(""KEY"",DIKKEY,0),U)" D ^DIC K DIC S DIC=DIE,X=+Y K:Y<0 X | 
|---|
| 111 | ;;^DD(.31,3,3) | 
|---|
| 112 | ;;=Answer '??' for more help. | 
|---|
| 113 | ;;^DD(.31,3,12) | 
|---|
| 114 | ;;=Root File of Index must equal File of Key. | 
|---|
| 115 | ;;^DD(.31,3,12.1) | 
|---|
| 116 | ;;=S DIC("S")="I 1 Q:'$D(DDS)!'$D(DIKKEY)  I $P(^(0),U,9)=$P(^DD(""KEY"",DIKKEY,0),U)" | 
|---|
| 117 | ;;^DD(.31,3,21,0) | 
|---|
| 118 | ;;=^^3^3^2981120^ | 
|---|
| 119 | ;;^DD(.31,3,21,1,0) | 
|---|
| 120 | ;;=Answer with the index that FileMan should use to ensure that new key | 
|---|
| 121 | ;;^DD(.31,3,21,2,0) | 
|---|
| 122 | ;;=values are unique. It must be a new-style index that resides in the | 
|---|
| 123 | ;;^DD(.31,3,21,3,0) | 
|---|
| 124 | ;;=Index file, and must cross-reference the key fields in proper sequence. | 
|---|
| 125 | ;;^DD(.31,3,"DT") | 
|---|
| 126 | ;;=2980611 | 
|---|
| 127 | ;;^DD(.312,0) | 
|---|
| 128 | ;;=FIELD SUB-FIELD^^1^3 | 
|---|
| 129 | ;;^DD(.312,0,"DT") | 
|---|
| 130 | ;;=2960219 | 
|---|
| 131 | ;;^DD(.312,0,"ID","WRITE") | 
|---|
| 132 | ;;=D EN^DDIOL("   "_$P(^(0),U,2),"","?0") | 
|---|
| 133 | ;;^DD(.312,0,"IX","B",.312,.01) | 
|---|
| 134 | ;;= | 
|---|
| 135 | ;;^DD(.312,0,"NM","FIELD") | 
|---|
| 136 | ;;= | 
|---|
| 137 | ;;^DD(.312,0,"UP") | 
|---|
| 138 | ;;=.31 | 
|---|
| 139 | ;;^DD(.312,.01,0) | 
|---|
| 140 | ;;=FIELD^MRFX^^0;1^D ITFLD^DIKKDD I $D(X) K:$L(X)>20!($L(X)<1) X | 
|---|
| 141 | ;;^DD(.312,.01,1,0) | 
|---|
| 142 | ;;=^.1 | 
|---|
| 143 | ;;^DD(.312,.01,1,1,0) | 
|---|
| 144 | ;;=.312^B | 
|---|
| 145 | ;;^DD(.312,.01,1,1,1) | 
|---|
| 146 | ;;=S ^DD("KEY",DA(1),2,"B",$E(X,1,30),DA)="" | 
|---|
| 147 | ;;^DD(.312,.01,1,1,2) | 
|---|
| 148 | ;;=K ^DD("KEY",DA(1),2,"B",$E(X,1,30),DA) | 
|---|
| 149 | ;;^DD(.312,.01,1,1,3) | 
|---|
| 150 | ;;=LETS DEVELOPER PICK KEY FIELDS BY NUMBER | 
|---|
| 151 | ;;^DD(.312,.01,1,1,"%D",0) | 
|---|
| 152 | ;;=^^2^2^2980908^ | 
|---|
| 153 | ;;^DD(.312,.01,1,1,"%D",1,0) | 
|---|
| 154 | ;;=The B index, on the .01 (Field) of the Fields multiple, lets the developer | 
|---|
| 155 | ;;^DD(.312,.01,1,1,"%D",2,0) | 
|---|
| 156 | ;;=pick key fields by field number. | 
|---|
| 157 | ;;^DD(.312,.01,1,2,0) | 
|---|
| 158 | ;;=^^TRIGGER^.312^.02 | 
|---|
| 159 | ;;^DD(.312,.01,1,2,1) | 
|---|
| 160 | ;;=K DIV S DIV=X,D0=DA(1),DIV(0)=D0,D1=DA,DIV(1)=D1 S Y(1)=$S($D(^DD("KEY",D0,2,D1,0)):^(0),1:"") S X=$P(Y(1),U,2),X=X S DIU=X K Y X ^DD(.312,.01,1,2,1.1) X ^DD(.312,.01,1,2,1.4) | 
|---|
| 161 | ;;^DD(.312,.01,1,2,1.1) | 
|---|
| 162 | ;;=S X=DIV S X=$P(^DD("KEY",DA(1),0),U) | 
|---|
| 163 | ;;^DD(.312,.01,1,2,1.4) | 
|---|
| 164 | ;;=S DIH=$S($D(^DD("KEY",DIV(0),2,DIV(1),0)):^(0),1:""),DIV=X S $P(^(0),U,2)=DIV,DIH=.312,DIG=.02 D ^DICR:$O(^DD(DIH,DIG,1,0))>0 | 
|---|
| 165 | ;;^DD(.312,.01,1,2,2) | 
|---|
| 166 | ;;=Q | 
|---|
| 167 | ;;^DD(.312,.01,1,2,"CREATE VALUE") | 
|---|
| 168 | ;;=S X=$P(^DD("KEY",DA(1),0),U) | 
|---|
| 169 | ;;^DD(.312,.01,1,2,"DELETE VALUE") | 
|---|
| 170 | ;;=NO EFFECT | 
|---|
| 171 | ;;^DD(.312,.01,1,2,"DT") | 
|---|
| 172 | ;;=2980310 | 
|---|
| 173 | ;;^DD(.312,.01,1,2,"FIELD") | 
|---|
| 174 | ;;=FILE | 
|---|
| 175 | ;;^DD(.312,.01,3) | 
|---|
| 176 | ;;=Answer must be 1-20 characters in length. Answer '??' for more help. | 
|---|
| 177 | ;;^DD(.312,.01,4) | 
|---|
| 178 | ;;=D EHFLD^DIKKDD | 
|---|
| 179 | ;;^DD(.312,.01,21,0) | 
|---|
| 180 | ;;=^^1^1^2980908^ | 
|---|
| 181 | ;;^DD(.312,.01,21,1,0) | 
|---|
| 182 | ;;=Answer must be the number of one of this key's fields. | 
|---|
| 183 | ;;^DD(.312,.01,"DT") | 
|---|
| 184 | ;;=2980611 | 
|---|
| 185 | ;;^DD(.312,.02,0) | 
|---|
| 186 | ;;=FILE^RNJ20,7I^^0;2^K:+X'=X!(X>999999999999)!(X<0)!(X?.E1"."8N.N) X | 
|---|
| 187 | ;;^DD(.312,.02,.1) | 
|---|
| 188 | ;;= | 
|---|
| 189 | ;;^DD(.312,.02,1,0) | 
|---|
| 190 | ;;=^.1^^0 | 
|---|
| 191 | ;;^DD(.312,.02,3) | 
|---|
| 192 | ;;=Type a Number between 0 and 999999999999, 7 Decimal Digits. Answer '??' for more help. | 
|---|
| 193 | ;;^DD(.312,.02,5,1,0) | 
|---|
| 194 | ;;=.312^.01^2 | 
|---|
| 195 | ;;^DD(.312,.02,21,0) | 
|---|
| 196 | ;;=^^3^3^2980908^ | 
|---|
| 197 | ;;^DD(.312,.02,21,1,0) | 
|---|
| 198 | ;;=Answer must be the number of the file that holds this key field. It must | 
|---|
| 199 | ;;^DD(.312,.02,21,2,0) | 
|---|
| 200 | ;;=equal the number of the file whose records are uniquiely identified by | 
|---|
| 201 | ;;^DD(.312,.02,21,3,0) | 
|---|
| 202 | ;;=this key. | 
|---|
| 203 | ;;^DD(.312,.02,"DT") | 
|---|
| 204 | ;;=2980908 | 
|---|
| 205 | ;;^DD(.312,1,0) | 
|---|
| 206 | ;;=SEQUENCE NUMBER^RNJ3,0^^0;3^K:+X'=X!(X>125)!(X<1)!(X?.E1"."1N.N) X | 
|---|
| 207 | ;;^DD(.312,1,3) | 
|---|
| 208 | ;;=Answer must be between 1 and 125, with no decimal digits. Answer '??' for more help. | 
|---|