416DAT

Hex Artifact Content
Login

Artifact c66f1fce7f72dc7c7e6bf6830e23ff61a96a5e68:


0000: 2f 2a 2a 0a 20 2a 20 4f 72 69 65 6e 74 44 42 20  /**. * OrientDB 
0010: 63 6c 69 65 6e 74 20 62 69 6e 64 69 6e 67 20 66  client binding f
0020: 6f 72 20 59 43 53 42 2e 0a 20 2a 0a 20 2a 20 53  or YCSB.. *. * S
0030: 75 62 6d 69 74 74 65 64 20 62 79 20 4c 75 63 61  ubmitted by Luca
0040: 20 47 61 72 75 6c 6c 69 20 6f 6e 20 35 2f 31 30   Garulli on 5/10
0050: 2f 32 30 31 32 2e 0a 20 2a 0a 20 2a 2f 0a 0a 70  /2012.. *. */..p
0060: 61 63 6b 61 67 65 20 63 6f 6d 2e 79 61 68 6f 6f  ackage com.yahoo
0070: 2e 79 63 73 62 2e 64 62 3b 0a 0a 69 6d 70 6f 72  .ycsb.db;..impor
0080: 74 20 6a 61 76 61 2e 75 74 69 6c 2e 43 6f 6c 6c  t java.util.Coll
0090: 65 63 74 69 6f 6e 3b 0a 69 6d 70 6f 72 74 20 6a  ection;.import j
00a0: 61 76 61 2e 75 74 69 6c 2e 48 61 73 68 4d 61 70  ava.util.HashMap
00b0: 3b 0a 69 6d 70 6f 72 74 20 6a 61 76 61 2e 75 74  ;.import java.ut
00c0: 69 6c 2e 4d 61 70 3b 0a 69 6d 70 6f 72 74 20 6a  il.Map;.import j
00d0: 61 76 61 2e 75 74 69 6c 2e 4d 61 70 2e 45 6e 74  ava.util.Map.Ent
00e0: 72 79 3b 0a 69 6d 70 6f 72 74 20 6a 61 76 61 2e  ry;.import java.
00f0: 75 74 69 6c 2e 50 72 6f 70 65 72 74 69 65 73 3b  util.Properties;
0100: 0a 69 6d 70 6f 72 74 20 6a 61 76 61 2e 75 74 69  .import java.uti
0110: 6c 2e 53 65 74 3b 0a 69 6d 70 6f 72 74 20 6a 61  l.Set;.import ja
0120: 76 61 2e 75 74 69 6c 2e 56 65 63 74 6f 72 3b 0a  va.util.Vector;.
0130: 69 6d 70 6f 72 74 20 6a 61 76 61 2e 75 74 69 6c  import java.util
0140: 2e 52 61 6e 64 6f 6d 3b 0a 69 6d 70 6f 72 74 20  .Random;.import 
0150: 6a 61 76 61 2e 75 74 69 6c 2e 4c 69 73 74 3b 0a  java.util.List;.
0160: 69 6d 70 6f 72 74 20 6a 61 76 61 2e 75 74 69 6c  import java.util
0170: 2e 41 72 72 61 79 4c 69 73 74 3b 0a 69 6d 70 6f  .ArrayList;.impo
0180: 72 74 20 6a 61 76 61 2e 6c 61 6e 67 2e 49 6e 74  rt java.lang.Int
0190: 65 67 65 72 3b 0a 0a 69 6d 70 6f 72 74 20 63 6f  eger;..import co
01a0: 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c 6f 67  m.orientechnolog
01b0: 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6c 69 65 6e  ies.orient.clien
01c0: 74 2e 72 65 6d 6f 74 65 2e 4f 53 65 72 76 65 72  t.remote.OServer
01d0: 41 64 6d 69 6e 3b 0a 69 6d 70 6f 72 74 20 63 6f  Admin;.import co
01e0: 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c 6f 67  m.orientechnolog
01f0: 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f 72 65 2e  ies.orient.core.
0200: 63 6f 6e 66 69 67 2e 4f 47 6c 6f 62 61 6c 43 6f  config.OGlobalCo
0210: 6e 66 69 67 75 72 61 74 69 6f 6e 3b 0a 69 6d 70  nfiguration;.imp
0220: 6f 72 74 20 63 6f 6d 2e 6f 72 69 65 6e 74 65 63  ort com.orientec
0230: 68 6e 6f 6c 6f 67 69 65 73 2e 6f 72 69 65 6e 74  hnologies.orient
0240: 2e 63 6f 72 65 2e 64 62 2e 64 6f 63 75 6d 65 6e  .core.db.documen
0250: 74 2e 4f 44 61 74 61 62 61 73 65 44 6f 63 75 6d  t.ODatabaseDocum
0260: 65 6e 74 54 78 3b 0a 69 6d 70 6f 72 74 20 63 6f  entTx;.import co
0270: 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c 6f 67  m.orientechnolog
0280: 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f 72 65 2e  ies.orient.core.
0290: 64 62 2e 64 6f 63 75 6d 65 6e 74 2e 4f 44 61 74  db.document.ODat
02a0: 61 62 61 73 65 44 6f 63 75 6d 65 6e 74 50 6f 6f  abaseDocumentPoo
02b0: 6c 3b 0a 69 6d 70 6f 72 74 20 63 6f 6d 2e 6f 72  l;.import com.or
02c0: 69 65 6e 74 65 63 68 6e 6f 6c 6f 67 69 65 73 2e  ientechnologies.
02d0: 6f 72 69 65 6e 74 2e 63 6f 72 65 2e 64 62 2e 4f  orient.core.db.O
02e0: 44 61 74 61 62 61 73 65 43 6f 6d 70 6c 65 78 2e  DatabaseComplex.
02f0: 4f 50 45 52 41 54 49 4f 4e 5f 4d 4f 44 45 3b 0a  OPERATION_MODE;.
0300: 69 6d 70 6f 72 74 20 63 6f 6d 2e 6f 72 69 65 6e  import com.orien
0310: 74 65 63 68 6e 6f 6c 6f 67 69 65 73 2e 6f 72 69  technologies.ori
0320: 65 6e 74 2e 63 6f 72 65 2e 64 62 2e 4f 44 61 74  ent.core.db.ODat
0330: 61 62 61 73 65 52 65 63 6f 72 64 54 68 72 65 61  abaseRecordThrea
0340: 64 4c 6f 63 61 6c 3b 0a 69 6d 70 6f 72 74 20 63  dLocal;.import c
0350: 6f 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c 6f  om.orientechnolo
0360: 67 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f 72 65  gies.orient.core
0370: 2e 73 74 6f 72 61 67 65 2e 2a 3b 0a 69 6d 70 6f  .storage.*;.impo
0380: 72 74 20 63 6f 6d 2e 6f 72 69 65 6e 74 65 63 68  rt com.orientech
0390: 6e 6f 6c 6f 67 69 65 73 2e 6f 72 69 65 6e 74 2e  nologies.orient.
03a0: 63 6f 72 65 2e 69 64 2e 4f 43 6c 75 73 74 65 72  core.id.OCluster
03b0: 50 6f 73 69 74 69 6f 6e 3b 0a 69 6d 70 6f 72 74  Position;.import
03c0: 20 63 6f 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f   com.orientechno
03d0: 6c 6f 67 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f  logies.orient.co
03e0: 72 65 2e 69 64 2e 4f 52 65 63 6f 72 64 49 64 3b  re.id.ORecordId;
03f0: 0a 69 6d 70 6f 72 74 20 63 6f 6d 2e 6f 72 69 65  .import com.orie
0400: 6e 74 65 63 68 6e 6f 6c 6f 67 69 65 73 2e 6f 72  ntechnologies.or
0410: 69 65 6e 74 2e 63 6f 72 65 2e 64 69 63 74 69 6f  ient.core.dictio
0420: 6e 61 72 79 2e 4f 44 69 63 74 69 6f 6e 61 72 79  nary.ODictionary
0430: 3b 0a 69 6d 70 6f 72 74 20 63 6f 6d 2e 6f 72 69  ;.import com.ori
0440: 65 6e 74 65 63 68 6e 6f 6c 6f 67 69 65 73 2e 6f  entechnologies.o
0450: 72 69 65 6e 74 2e 63 6f 72 65 2e 69 6e 74 65 6e  rient.core.inten
0460: 74 2e 4f 49 6e 74 65 6e 74 4d 61 73 73 69 76 65  t.OIntentMassive
0470: 49 6e 73 65 72 74 3b 0a 69 6d 70 6f 72 74 20 63  Insert;.import c
0480: 6f 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c 6f  om.orientechnolo
0490: 67 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f 72 65  gies.orient.core
04a0: 2e 72 65 63 6f 72 64 2e 4f 52 65 63 6f 72 64 49  .record.ORecordI
04b0: 6e 74 65 72 6e 61 6c 3b 0a 69 6d 70 6f 72 74 20  nternal;.import 
04c0: 63 6f 6d 2e 6f 72 69 65 6e 74 65 63 68 6e 6f 6c  com.orientechnol
04d0: 6f 67 69 65 73 2e 6f 72 69 65 6e 74 2e 63 6f 72  ogies.orient.cor
04e0: 65 2e 72 65 63 6f 72 64 2e 69 6d 70 6c 2e 4f 44  e.record.impl.OD
04f0: 6f 63 75 6d 65 6e 74 3b 0a 69 6d 70 6f 72 74 20  ocument;.import 
0500: 63 6f 6d 2e 79 61 68 6f 6f 2e 79 63 73 62 2e 42  com.yahoo.ycsb.B
0510: 79 74 65 49 74 65 72 61 74 6f 72 3b 0a 69 6d 70  yteIterator;.imp
0520: 6f 72 74 20 63 6f 6d 2e 79 61 68 6f 6f 2e 79 63  ort com.yahoo.yc
0530: 73 62 2e 44 42 3b 0a 69 6d 70 6f 72 74 20 63 6f  sb.DB;.import co
0540: 6d 2e 79 61 68 6f 6f 2e 79 63 73 62 2e 44 42 45  m.yahoo.ycsb.DBE
0550: 78 63 65 70 74 69 6f 6e 3b 0a 69 6d 70 6f 72 74  xception;.import
0560: 20 63 6f 6d 2e 79 61 68 6f 6f 2e 79 63 73 62 2e   com.yahoo.ycsb.
0570: 53 74 72 69 6e 67 42 79 74 65 49 74 65 72 61 74  StringByteIterat
0580: 6f 72 3b 0a 69 6d 70 6f 72 74 20 63 6f 6d 2e 79  or;.import com.y
0590: 61 68 6f 6f 2e 79 63 73 62 2e 48 6f 73 74 3b 0a  ahoo.ycsb.Host;.
05a0: 0a 2f 2a 2a 0a 20 2a 20 4f 72 69 65 6e 74 44 42  ./**. * OrientDB
05b0: 20 63 6c 69 65 6e 74 20 66 6f 72 20 59 43 53 42   client for YCSB
05c0: 20 66 72 61 6d 65 77 6f 72 6b 2e 0a 20 2a 20 0a   framework.. * .
05d0: 20 2a 20 50 72 6f 70 65 72 74 69 65 73 20 74 6f   * Properties to
05e0: 20 73 65 74 3a 0a 20 2a 20 0a 20 2a 20 6f 72 69   set:. * . * ori
05f0: 65 6e 74 64 62 2e 75 72 6c 3d 6c 6f 63 61 6c 3a  entdb.url=local:
0600: 43 3a 2f 74 65 6d 70 2f 64 61 74 61 62 61 73 65  C:/temp/database
0610: 73 2f 79 63 73 62 20 6f 72 20 72 65 6d 6f 74 65  s/ycsb or remote
0620: 3a 6c 6f 63 61 6c 68 6f 73 74 3a 32 34 32 34 20  :localhost:2424 
0630: 3c 62 72 3e 0a 20 2a 20 6f 72 69 65 6e 74 64 62  <br>. * orientdb
0640: 2e 64 61 74 61 62 61 73 65 3d 79 63 73 62 20 3c  .database=ycsb <
0650: 62 72 3e 0a 20 2a 20 6f 72 69 65 6e 74 64 62 2e  br>. * orientdb.
0660: 75 73 65 72 3d 61 64 6d 69 6e 20 3c 62 72 3e 0a  user=admin <br>.
0670: 20 2a 20 6f 72 69 65 6e 74 64 62 2e 70 61 73 73   * orientdb.pass
0680: 77 6f 72 64 3d 61 64 6d 69 6e 20 3c 62 72 3e 0a  word=admin <br>.
0690: 20 2a 20 0a 20 2a 20 40 61 75 74 68 6f 72 20 4c   * . * @author L
06a0: 75 63 61 20 47 61 72 75 6c 6c 69 0a 20 2a 20 0a  uca Garulli. * .
06b0: 20 2a 2f 0a 70 75 62 6c 69 63 20 63 6c 61 73 73   */.public class
06c0: 20 4f 72 69 65 6e 74 44 42 43 6c 69 65 6e 74 20   OrientDBClient 
06d0: 65 78 74 65 6e 64 73 20 44 42 20 7b 0a 0a 20 20  extends DB {..  
06e0: 2f 2f 20 70 72 69 76 61 74 65 20 4f 44 61 74 61  // private OData
06f0: 62 61 73 65 44 6f 63 75 6d 65 6e 74 54 78 20 20  baseDocumentTx  
0700: 20 20 20 20 20 20 20 20 20 20 20 20 64 62 3b 0a              db;.
0710: 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69 63    private static
0720: 20 66 69 6e 61 6c 20 53 74 72 69 6e 67 20 20 20   final String   
0730: 20 20 20 20 20 20 20 20 20 20 20 43 4c 41 53 53             CLASS
0740: 20 3d 20 22 75 73 65 72 74 61 62 6c 65 22 3b 0a   = "usertable";.
0750: 20 20 70 72 69 76 61 74 65 20 4f 44 69 63 74 69    private ODicti
0760: 6f 6e 61 72 79 3c 4f 52 65 63 6f 72 64 49 6e 74  onary<ORecordInt
0770: 65 72 6e 61 6c 3c 3f 3e 3e 20 20 64 69 63 74 69  ernal<?>>  dicti
0780: 6f 6e 61 72 79 3b 0a 20 20 70 72 69 76 61 74 65  onary;.  private
0790: 20 4f 53 65 72 76 65 72 41 64 6d 69 6e 20 20 20   OServerAdmin   
07a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
07b0: 20 20 73 65 72 76 65 72 41 64 6d 69 6e 3b 0a 20    serverAdmin;. 
07c0: 20 70 72 69 76 61 74 65 20 4c 69 73 74 3c 48 6f   private List<Ho
07d0: 73 74 3e 20 20 20 20 20 20 20 20 20 20 20 20 20  st>             
07e0: 20 20 20 20 20 20 20 20 20 20 6c 69 73 74 48 6f            listHo
07f0: 73 74 73 3b 0a 20 20 0a 20 20 70 72 69 76 61 74  sts;.  .  privat
0800: 65 20 4d 61 70 3c 53 74 72 69 6e 67 2c 20 4f 44  e Map<String, OD
0810: 61 74 61 62 61 73 65 44 6f 63 75 6d 65 6e 74 54  atabaseDocumentT
0820: 78 3e 20 64 61 74 61 62 61 73 65 73 3b 0a 20 20  x> databases;.  
0830: 70 72 69 76 61 74 65 20 4d 61 70 3c 53 74 72 69  private Map<Stri
0840: 6e 67 2c 20 4f 44 69 63 74 69 6f 6e 61 72 79 3c  ng, ODictionary<
0850: 4f 52 65 63 6f 72 64 49 6e 74 65 72 6e 61 6c 3c  ORecordInternal<
0860: 3f 3e 3e 3e 20 64 69 63 74 69 6f 6e 61 72 69 65  ?>>> dictionarie
0870: 73 3b 0a 0a 20 20 70 72 69 76 61 74 65 20 53 74  s;..  private St
0880: 72 69 6e 67 20 75 73 65 72 3b 0a 20 20 70 72 69  ring user;.  pri
0890: 76 61 74 65 20 53 74 72 69 6e 67 20 70 61 73 73  vate String pass
08a0: 77 6f 72 64 3b 0a 20 20 70 72 69 76 61 74 65 20  word;.  private 
08b0: 42 6f 6f 6c 65 61 6e 20 6e 65 77 64 62 3b 0a 0a  Boolean newdb;..
08c0: 20 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20    public static 
08d0: 66 69 6e 61 6c 20 69 6e 74 20 4d 49 4e 5f 4b 45  final int MIN_KE
08e0: 59 20 3d 20 30 3b 0a 20 20 70 75 62 6c 69 63 20  Y = 0;.  public 
08f0: 73 74 61 74 69 63 20 66 69 6e 61 6c 20 69 6e 74  static final int
0900: 20 4d 41 58 5f 4b 45 59 20 3d 20 31 30 3b 0a 0a   MAX_KEY = 10;..
0910: 20 20 2f 2a 2a 0a 20 20 20 2a 20 49 6e 69 74 69    /**.   * Initi
0920: 61 6c 69 7a 65 20 61 6e 79 20 73 74 61 74 65 20  alize any state 
0930: 66 6f 72 20 74 68 69 73 20 44 42 2e 20 43 61 6c  for this DB. Cal
0940: 6c 65 64 20 6f 6e 63 65 20 70 65 72 20 44 42 20  led once per DB 
0950: 69 6e 73 74 61 6e 63 65 3b 20 74 68 65 72 65 20  instance; there 
0960: 69 73 20 6f 6e 65 20 44 42 20 69 6e 73 74 61 6e  is one DB instan
0970: 63 65 20 70 65 72 20 63 6c 69 65 6e 74 20 74 68  ce per client th
0980: 72 65 61 64 2e 0a 20 20 20 2a 2f 0a 20 20 70 75  read..   */.  pu
0990: 62 6c 69 63 20 76 6f 69 64 20 69 6e 69 74 28 29  blic void init()
09a0: 20 74 68 72 6f 77 73 20 44 42 45 78 63 65 70 74   throws DBExcept
09b0: 69 6f 6e 20 7b 0a 20 20 20 20 2f 2f 20 69 6e 69  ion {.    // ini
09c0: 74 69 61 6c 69 7a 65 20 4f 72 69 65 6e 74 44 42  tialize OrientDB
09d0: 20 64 72 69 76 65 72 0a 20 20 20 20 50 72 6f 70   driver.    Prop
09e0: 65 72 74 69 65 73 20 70 72 6f 70 73 20 3d 20 67  erties props = g
09f0: 65 74 50 72 6f 70 65 72 74 69 65 73 28 29 3b 0a  etProperties();.
0a00: 0a 20 20 20 20 53 74 72 69 6e 67 20 75 72 6c 73  .    String urls
0a10: 20 3d 20 70 72 6f 70 73 2e 67 65 74 50 72 6f 70   = props.getProp
0a20: 65 72 74 79 28 22 6f 72 69 65 6e 74 64 62 2e 75  erty("orientdb.u
0a30: 72 6c 73 22 2c 20 22 72 65 6d 6f 74 65 3a 6c 6f  rls", "remote:lo
0a40: 63 61 6c 68 6f 73 74 2f 79 63 73 62 22 29 3b 0a  calhost/ycsb");.
0a50: 20 20 20 20 75 73 65 72 20 3d 20 70 72 6f 70 73      user = props
0a60: 2e 67 65 74 50 72 6f 70 65 72 74 79 28 22 6f 72  .getProperty("or
0a70: 69 65 6e 74 64 62 2e 75 73 65 72 22 2c 20 22 72  ientdb.user", "r
0a80: 63 68 6f 77 22 29 3b 0a 20 20 20 20 70 61 73 73  chow");.    pass
0a90: 77 6f 72 64 20 3d 20 70 72 6f 70 73 2e 67 65 74  word = props.get
0aa0: 50 72 6f 70 65 72 74 79 28 22 6f 72 69 65 6e 74  Property("orient
0ab0: 64 62 2e 70 61 73 73 77 6f 72 64 22 2c 20 22 68  db.password", "h
0ac0: 69 72 61 79 6d 6f 6e 64 22 29 3b 0a 20 20 20 20  iraymond");.    
0ad0: 6e 65 77 64 62 20 3d 20 42 6f 6f 6c 65 61 6e 2e  newdb = Boolean.
0ae0: 70 61 72 73 65 42 6f 6f 6c 65 61 6e 28 70 72 6f  parseBoolean(pro
0af0: 70 73 2e 67 65 74 50 72 6f 70 65 72 74 79 28 22  ps.getProperty("
0b00: 6f 72 69 65 6e 74 64 62 2e 6e 65 77 64 62 22 2c  orientdb.newdb",
0b10: 20 22 66 61 6c 73 65 22 29 29 3b 0a 0a 20 20 20   "false"));..   
0b20: 20 53 74 72 69 6e 67 5b 5d 20 61 6c 6c 5f 75 72   String[] all_ur
0b30: 6c 73 20 3d 20 75 72 6c 73 2e 73 70 6c 69 74 28  ls = urls.split(
0b40: 22 2c 22 29 3b 0a 0a 20 20 20 20 2f 2f 20 53 65  ",");..    // Se
0b50: 74 20 62 75 63 6b 65 74 20 69 6e 74 65 72 76 61  t bucket interva
0b60: 6c 0a 20 20 20 20 69 6e 74 20 69 6e 74 65 72 76  l.    int interv
0b70: 61 6c 20 3d 20 28 4d 41 58 5f 4b 45 59 20 2d 20  al = (MAX_KEY - 
0b80: 4d 49 4e 5f 4b 45 59 29 20 2f 20 61 6c 6c 5f 75  MIN_KEY) / all_u
0b90: 72 6c 73 2e 6c 65 6e 67 74 68 3b 0a 0a 20 20 20  rls.length;..   
0ba0: 20 2f 2f 20 4c 69 73 74 20 74 6f 20 73 74 6f 72   // List to stor
0bb0: 65 20 68 6f 73 74 73 0a 20 20 20 20 6c 69 73 74  e hosts.    list
0bc0: 48 6f 73 74 73 20 3d 20 6e 65 77 20 41 72 72 61  Hosts = new Arra
0bd0: 79 4c 69 73 74 3c 48 6f 73 74 3e 28 29 3b 0a 0a  yList<Host>();..
0be0: 20 20 20 20 64 61 74 61 62 61 73 65 73 20 3d 20      databases = 
0bf0: 6e 65 77 20 48 61 73 68 4d 61 70 3c 53 74 72 69  new HashMap<Stri
0c00: 6e 67 2c 20 4f 44 61 74 61 62 61 73 65 44 6f 63  ng, ODatabaseDoc
0c10: 75 6d 65 6e 74 54 78 3e 28 61 6c 6c 5f 75 72 6c  umentTx>(all_url
0c20: 73 2e 6c 65 6e 67 74 68 29 3b 0a 20 20 20 20 64  s.length);.    d
0c30: 69 63 74 69 6f 6e 61 72 69 65 73 20 3d 20 6e 65  ictionaries = ne
0c40: 77 20 48 61 73 68 4d 61 70 3c 53 74 72 69 6e 67  w HashMap<String
0c50: 2c 20 4f 44 69 63 74 69 6f 6e 61 72 79 3c 4f 52  , ODictionary<OR
0c60: 65 63 6f 72 64 49 6e 74 65 72 6e 61 6c 3c 3f 3e  ecordInternal<?>
0c70: 3e 3e 28 61 6c 6c 5f 75 72 6c 73 2e 6c 65 6e 67  >>(all_urls.leng
0c80: 74 68 29 3b 0a 0a 20 20 20 20 2f 2f 20 50 6f 70  th);..    // Pop
0c90: 75 6c 61 74 65 20 68 6f 73 74 73 20 61 6e 64 20  ulate hosts and 
0ca0: 64 61 74 61 62 61 73 65 73 0a 20 20 20 20 66 6f  databases.    fo
0cb0: 72 28 20 69 6e 74 20 69 20 3d 20 30 3b 20 69 20  r( int i = 0; i 
0cc0: 3c 20 61 6c 6c 5f 75 72 6c 73 2e 6c 65 6e 67 74  < all_urls.lengt
0cd0: 68 3b 20 69 2b 2b 20 29 0a 20 20 20 20 7b 0a 20  h; i++ ).    {. 
0ce0: 20 20 20 20 20 6c 69 73 74 48 6f 73 74 73 2e 61       listHosts.a
0cf0: 64 64 28 20 6e 65 77 20 48 6f 73 74 28 69 2a 69  dd( new Host(i*i
0d00: 6e 74 65 72 76 61 6c 2c 20 28 69 2b 31 29 2a 69  nterval, (i+1)*i
0d10: 6e 74 65 72 76 61 6c 2c 20 61 6c 6c 5f 75 72 6c  nterval, all_url
0d20: 73 5b 69 5d 29 20 29 3b 0a 20 20 20 20 20 20 64  s[i]) );.      d
0d30: 61 74 61 62 61 73 65 73 2e 70 75 74 28 20 61 6c  atabases.put( al
0d40: 6c 5f 75 72 6c 73 5b 69 5d 2c 20 6e 65 77 20 4f  l_urls[i], new O
0d50: 44 61 74 61 62 61 73 65 44 6f 63 75 6d 65 6e 74  DatabaseDocument
0d60: 54 78 28 61 6c 6c 5f 75 72 6c 73 5b 69 5d 29 20  Tx(all_urls[i]) 
0d70: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 74 72  );.    }..    tr
0d80: 79 20 7b 0a 0a 20 20 20 20 20 20 2f 2f 20 53 79  y {..      // Sy
0d90: 73 74 65 6d 2e 6f 75 74 2e 70 72 69 6e 74 6c 6e  stem.out.println
0da0: 28 22 4f 72 69 65 6e 74 44 42 20 6c 6f 61 64 69  ("OrientDB loadi
0db0: 6e 67 20 64 61 74 61 62 61 73 65 20 75 72 6c 20  ng database url 
0dc0: 3d 20 22 20 2b 20 75 72 6c 29 3b 0a 0a 20 20 20  = " + url);..   
0dd0: 20 20 20 4f 47 6c 6f 62 61 6c 43 6f 6e 66 69 67     OGlobalConfig
0de0: 75 72 61 74 69 6f 6e 2e 53 54 4f 52 41 47 45 5f  uration.STORAGE_
0df0: 4b 45 45 50 5f 4f 50 45 4e 2e 73 65 74 56 61 6c  KEEP_OPEN.setVal
0e00: 75 65 28 66 61 6c 73 65 29 3b 0a 20 20 20 20 20  ue(false);.     
0e10: 20 2f 2f 20 4f 47 6c 6f 62 61 6c 43 6f 6e 66 69   // OGlobalConfi
0e20: 67 75 72 61 74 69 6f 6e 2e 43 4c 49 45 4e 54 5f  guration.CLIENT_
0e30: 43 48 41 4e 4e 45 4c 5f 4d 41 58 5f 50 4f 4f 4c  CHANNEL_MAX_POOL
0e40: 2e 73 65 74 56 61 6c 75 65 28 35 30 30 30 29 3b  .setValue(5000);
0e50: 0a 20 20 20 20 20 20 2f 2f 20 4f 47 6c 6f 62 61  .      // OGloba
0e60: 6c 43 6f 6e 66 69 67 75 72 61 74 69 6f 6e 2e 4e  lConfiguration.N
0e70: 45 54 57 4f 52 4b 5f 4c 4f 43 4b 5f 54 49 4d 45  ETWORK_LOCK_TIME
0e80: 4f 55 54 2e 73 65 74 56 61 6c 75 65 28 31 30 30  OUT.setValue(100
0e90: 30 30 29 3b 0a 20 20 20 20 20 20 0a 20 20 20 20  00);.      .    
0ea0: 20 20 2f 2f 20 53 65 74 20 75 70 20 74 68 65 20    // Set up the 
0eb0: 44 42 0a 20 20 20 20 20 20 73 65 74 75 70 44 42  DB.      setupDB
0ec0: 28 29 3b 0a 0a 20 20 20 20 20 20 2f 2f 20 53 79  ();..      // Sy
0ed0: 73 74 65 6d 2e 6f 75 74 2e 70 72 69 6e 74 6c 6e  stem.out.println
0ee0: 28 22 4f 72 69 65 6e 74 44 42 20 63 6f 6e 6e 65  ("OrientDB conne
0ef0: 63 74 69 6f 6e 20 63 72 65 61 74 65 64 20 77 69  ction created wi
0f00: 74 68 20 22 20 2b 20 75 72 6c 29 3b 0a 0a 20 20  th " + url);..  
0f10: 20 20 7d 20 63 61 74 63 68 20 28 45 78 63 65 70    } catch (Excep
0f20: 74 69 6f 6e 20 65 31 29 20 7b 0a 20 20 20 20 20  tion e1) {.     
0f30: 20 53 79 73 74 65 6d 2e 65 72 72 2e 70 72 69 6e   System.err.prin
0f40: 74 6c 6e 28 22 43 6f 75 6c 64 20 6e 6f 74 20 69  tln("Could not i
0f50: 6e 69 74 69 61 6c 69 7a 65 20 4f 72 69 65 6e 74  nitialize Orient
0f60: 44 42 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 70 6f  DB connection po
0f70: 6f 6c 20 66 6f 72 20 4c 6f 61 64 65 72 3a 20 22  ol for Loader: "
0f80: 20 2b 20 65 31 2e 74 6f 53 74 72 69 6e 67 28 29   + e1.toString()
0f90: 29 3b 0a 20 20 20 20 20 20 65 31 2e 70 72 69 6e  );.      e1.prin
0fa0: 74 53 74 61 63 6b 54 72 61 63 65 28 29 3b 0a 20  tStackTrace();. 
0fb0: 20 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20 20       return;.   
0fc0: 20 7d 0a 0a 20 20 7d 0a 0a 20 20 70 75 62 6c 69   }..  }..  publi
0fd0: 63 20 76 6f 69 64 20 73 65 74 75 70 44 42 28 29  c void setupDB()
0fe0: 0a 20 20 7b 0a 0a 20 20 20 20 74 72 79 20 7b 0a  .  {..    try {.
0ff0: 0a 20 20 20 20 20 20 66 6f 72 28 20 45 6e 74 72  .      for( Entr
1000: 79 3c 53 74 72 69 6e 67 2c 20 4f 44 61 74 61 62  y<String, ODatab
1010: 61 73 65 44 6f 63 75 6d 65 6e 74 54 78 3e 20 65  aseDocumentTx> e
1020: 6e 74 72 79 20 3a 20 64 61 74 61 62 61 73 65 73  ntry : databases
1030: 2e 65 6e 74 72 79 53 65 74 28 29 20 29 0a 20 20  .entrySet() ).  
1040: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 53 74      {.        St
1050: 72 69 6e 67 20 75 72 6c 20 3d 20 65 6e 74 72 79  ring url = entry
1060: 2e 67 65 74 4b 65 79 28 29 3b 0a 20 20 20 20 20  .getKey();.     
1070: 20 20 20 4f 44 61 74 61 62 61 73 65 44 6f 63 75     ODatabaseDocu
1080: 6d 65 6e 74 54 78 20 64 61 74 61 62 61 73 65 20  mentTx database 
1090: 3d 20 65 6e 74 72 79 2e 67 65 74 56 61 6c 75 65  = entry.getValue
10a0: 28 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20  ();..        // 
10b0: 45 73 74 61 62 6c 69 73 68 20 61 20 72 65 6d 6f  Establish a remo
10c0: 74 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 74 6f  te connection to
10d0: 20 74 68 65 20 68 6f 73 74 20 28 75 72 6c 29 0a   the host (url).
10e0: 20 20 20 20 20 20 20 20 73 65 72 76 65 72 41 64          serverAd
10f0: 6d 69 6e 20 3d 20 6e 65 77 20 4f 53 65 72 76 65  min = new OServe
1100: 72 41 64 6d 69 6e 28 75 72 6c 29 2e 63 6f 6e 6e  rAdmin(url).conn
1110: 65 63 74 28 75 73 65 72 2c 20 70 61 73 73 77 6f  ect(user, passwo
1120: 72 64 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f  rd);..        //
1130: 20 43 68 65 63 6b 20 69 66 20 64 61 74 61 62 61   Check if databa
1140: 73 65 20 65 78 69 73 74 73 0a 20 20 20 20 20 20  se exists.      
1150: 20 20 69 66 28 20 73 65 72 76 65 72 41 64 6d 69    if( serverAdmi
1160: 6e 2e 65 78 69 73 74 73 44 61 74 61 62 61 73 65  n.existsDatabase
1170: 28 29 20 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  () ).        {. 
1180: 20 20 20 20 20 20 20 20 20 2f 2f 20 52 65 2d 63           // Re-c
1190: 72 65 61 74 65 20 44 42 0a 20 20 20 20 20 20 20  reate DB.       
11a0: 20 20 20 69 66 28 6e 65 77 64 62 29 0a 20 20 20     if(newdb).   
11b0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
11c0: 20 20 20 20 20 2f 2f 20 53 79 73 74 65 6d 2e 6f       // System.o
11d0: 75 74 2e 70 72 69 6e 74 6c 6e 28 22 4f 72 69 65  ut.println("Orie
11e0: 6e 74 44 42 20 64 72 6f 70 20 61 6e 64 20 72 65  ntDB drop and re
11f0: 63 72 65 61 74 65 20 66 72 65 73 68 20 64 62 22  create fresh db"
1200: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 73  );.            s
1210: 65 72 76 65 72 41 64 6d 69 6e 2e 63 6f 6e 6e 65  erverAdmin.conne
1220: 63 74 28 75 73 65 72 2c 20 70 61 73 73 77 6f 72  ct(user, passwor
1230: 64 29 2e 64 72 6f 70 44 61 74 61 62 61 73 65 28  d).dropDatabase(
1240: 29 2e 63 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20  ).close();.     
1250: 20 20 20 20 20 20 20 73 65 72 76 65 72 41 64 6d         serverAdm
1260: 69 6e 2e 63 6f 6e 6e 65 63 74 28 75 73 65 72 2c  in.connect(user,
1270: 20 70 61 73 73 77 6f 72 64 29 2e 63 72 65 61 74   password).creat
1280: 65 44 61 74 61 62 61 73 65 28 22 64 6f 63 75 6d  eDatabase("docum
1290: 65 6e 74 22 2c 20 22 6c 6f 63 61 6c 22 29 2e 63  ent", "local").c
12a0: 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20 20 20 20  lose();.        
12b0: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
12c0: 20 20 20 20 20 20 2f 2f 20 44 61 74 61 62 61 73        // Databas
12d0: 65 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73 74  e does not exist
12e0: 2c 20 63 72 65 61 74 65 20 6e 65 77 20 6f 6e 65  , create new one
12f0: 0a 20 20 20 20 20 20 20 20 65 6c 73 65 0a 20 20  .        else.  
1300: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
1310: 20 20 2f 2f 20 53 79 73 74 65 6d 2e 6f 75 74 2e    // System.out.
1320: 70 72 69 6e 74 6c 6e 28 22 4f 72 69 65 6e 74 44  println("OrientD
1330: 42 20 64 61 74 61 62 61 73 65 20 6e 6f 74 20 66  B database not f
1340: 6f 75 6e 64 2c 20 63 72 65 61 74 65 20 66 72 65  ound, create fre
1350: 73 68 20 64 62 22 29 3b 0a 20 20 20 20 20 20 20  sh db");.       
1360: 20 20 20 73 65 72 76 65 72 41 64 6d 69 6e 2e 63     serverAdmin.c
1370: 6f 6e 6e 65 63 74 28 75 73 65 72 2c 20 70 61 73  onnect(user, pas
1380: 73 77 6f 72 64 29 2e 63 72 65 61 74 65 44 61 74  sword).createDat
1390: 61 62 61 73 65 28 22 64 6f 63 75 6d 65 6e 74 22  abase("document"
13a0: 2c 20 22 6c 6f 63 61 6c 22 29 2e 63 6c 6f 73 65  , "local").close
13b0: 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20  ();.        }.. 
13c0: 20 20 20 20 20 20 20 2f 2f 20 53 65 74 20 44 42         // Set DB
13d0: 20 70 72 6f 70 65 72 74 69 65 73 0a 20 20 20 20   properties.    
13e0: 20 20 20 20 64 61 74 61 62 61 73 65 2e 73 65 74      database.set
13f0: 50 72 6f 70 65 72 74 79 28 22 6d 69 6e 50 6f 6f  Property("minPoo
1400: 6c 22 2c 20 35 29 3b 0a 20 20 20 20 20 20 20 20  l", 5);.        
1410: 64 61 74 61 62 61 73 65 2e 73 65 74 50 72 6f 70  database.setProp
1420: 65 72 74 79 28 22 6d 61 78 50 6f 6f 6c 22 2c 20  erty("maxPool", 
1430: 32 30 30 29 3b 0a 20 20 20 20 20 20 20 20 0a 20  200);.        . 
1440: 20 20 20 20 20 20 20 2f 2f 20 4f 70 65 6e 20 44         // Open D
1450: 42 0a 20 20 20 20 20 20 20 20 64 61 74 61 62 61  B.        databa
1460: 73 65 2e 6f 70 65 6e 28 75 73 65 72 2c 20 70 61  se.open(user, pa
1470: 73 73 77 6f 72 64 29 3b 0a 0a 20 20 20 20 20 20  ssword);..      
1480: 20 20 2f 2f 20 47 65 74 20 64 69 63 74 69 6f 6e    // Get diction
1490: 61 72 79 20 66 6f 72 20 44 42 0a 20 20 20 20 20  ary for DB.     
14a0: 20 20 20 4f 44 69 63 74 69 6f 6e 61 72 79 3c 4f     ODictionary<O
14b0: 52 65 63 6f 72 64 49 6e 74 65 72 6e 61 6c 3c 3f  RecordInternal<?
14c0: 3e 3e 20 64 74 20 3d 20 64 61 74 61 62 61 73 65  >> dt = database
14d0: 2e 67 65 74 4d 65 74 61 64 61 74 61 28 29 2e 67  .getMetadata().g
14e0: 65 74 49 6e 64 65 78 4d 61 6e 61 67 65 72 28 29  etIndexManager()
14f0: 2e 67 65 74 44 69 63 74 69 6f 6e 61 72 79 28 29  .getDictionary()
1500: 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20 41 64  ;..        // Ad
1510: 64 20 64 69 63 74 69 6f 6e 61 72 79 0a 20 20 20  d dictionary.   
1520: 20 20 20 20 20 64 69 63 74 69 6f 6e 61 72 69 65       dictionarie
1530: 73 2e 70 75 74 28 20 75 72 6c 2c 20 64 74 20 29  s.put( url, dt )
1540: 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20 43 68  ;..        // Ch
1550: 65 63 6b 20 69 66 20 43 4c 41 53 53 20 65 78 69  eck if CLASS exi
1560: 73 74 73 20 65 6c 73 65 20 63 72 65 61 74 65 0a  sts else create.
1570: 20 20 20 20 20 20 20 20 69 66 20 28 21 64 61 74          if (!dat
1580: 61 62 61 73 65 2e 67 65 74 4d 65 74 61 64 61 74  abase.getMetadat
1590: 61 28 29 2e 67 65 74 53 63 68 65 6d 61 28 29 2e  a().getSchema().
15a0: 65 78 69 73 74 73 43 6c 61 73 73 28 43 4c 41 53  existsClass(CLAS
15b0: 53 29 29 0a 20 20 20 20 20 20 20 20 20 20 64 61  S)).          da
15c0: 74 61 62 61 73 65 2e 67 65 74 4d 65 74 61 64 61  tabase.getMetada
15d0: 74 61 28 29 2e 67 65 74 53 63 68 65 6d 61 28 29  ta().getSchema()
15e0: 2e 63 72 65 61 74 65 43 6c 61 73 73 28 43 4c 41  .createClass(CLA
15f0: 53 53 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f  SS);..        //
1600: 20 54 75 6e 65 20 44 42 20 66 6f 72 20 6d 61 73   Tune DB for mas
1610: 73 69 76 65 20 69 6e 73 65 72 74 69 6f 6e 73 0a  sive insertions.
1620: 20 20 20 20 20 20 20 20 64 61 74 61 62 61 73 65          database
1630: 2e 64 65 63 6c 61 72 65 49 6e 74 65 6e 74 28 6e  .declareIntent(n
1640: 65 77 20 4f 49 6e 74 65 6e 74 4d 61 73 73 69 76  ew OIntentMassiv
1650: 65 49 6e 73 65 72 74 28 29 29 3b 0a 0a 20 20 20  eInsert());..   
1660: 20 20 20 20 20 65 6e 74 72 79 2e 73 65 74 56 61       entry.setVa
1670: 6c 75 65 28 64 61 74 61 62 61 73 65 29 3b 0a 20  lue(database);. 
1680: 20 20 20 20 20 7d 20 0a 0a 20 20 20 20 7d 20 63       } ..    } c
1690: 61 74 63 68 20 28 45 78 63 65 70 74 69 6f 6e 20  atch (Exception 
16a0: 65 31 29 20 7b 0a 20 20 20 20 20 20 53 79 73 74  e1) {.      Syst
16b0: 65 6d 2e 65 72 72 2e 70 72 69 6e 74 6c 6e 28 22  em.err.println("
16c0: 43 6f 75 6c 64 20 6e 6f 74 20 69 6e 69 74 69 61  Could not initia
16d0: 6c 69 7a 65 20 4f 72 69 65 6e 74 44 42 20 63 6f  lize OrientDB co
16e0: 6e 6e 65 63 74 69 6f 6e 20 70 6f 6f 6c 20 66 6f  nnection pool fo
16f0: 72 20 4c 6f 61 64 65 72 3a 20 22 20 2b 20 65 31  r Loader: " + e1
1700: 2e 74 6f 53 74 72 69 6e 67 28 29 29 3b 0a 20 20  .toString());.  
1710: 20 20 20 20 65 31 2e 70 72 69 6e 74 53 74 61 63      e1.printStac
1720: 6b 54 72 61 63 65 28 29 3b 0a 20 20 20 20 20 20  kTrace();.      
1730: 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 20 20  return;.    }.  
1740: 7d 0a 0a 20 20 70 75 62 6c 69 63 20 53 74 72 69  }..  public Stri
1750: 6e 67 20 66 69 6e 64 48 6f 73 74 28 53 74 72 69  ng findHost(Stri
1760: 6e 67 20 6b 65 79 29 0a 20 20 7b 0a 20 20 20 20  ng key).  {.    
1770: 2f 2f 20 46 69 6e 64 20 66 69 72 73 74 20 6e 75  // Find first nu
1780: 6d 62 65 72 20 6f 66 20 6b 65 79 0a 20 20 20 20  mber of key.    
1790: 53 74 72 69 6e 67 20 73 74 72 49 6e 74 4b 65 79  String strIntKey
17a0: 20 3d 20 6b 65 79 2e 73 75 62 73 74 72 69 6e 67   = key.substring
17b0: 28 34 2c 20 35 29 3b 0a 0a 20 20 20 20 2f 2f 20  (4, 5);..    // 
17c0: 43 6f 6e 76 65 72 74 20 73 74 72 69 6e 67 20 74  Convert string t
17d0: 6f 20 69 6e 74 65 67 65 72 0a 20 20 20 20 69 6e  o integer.    in
17e0: 74 20 69 6e 74 4b 65 79 20 3d 20 49 6e 74 65 67  t intKey = Integ
17f0: 65 72 2e 70 61 72 73 65 49 6e 74 28 73 74 72 49  er.parseInt(strI
1800: 6e 74 4b 65 79 29 3b 0a 0a 20 20 20 20 2f 2f 20  ntKey);..    // 
1810: 46 69 6e 64 20 77 68 69 63 68 20 68 6f 73 74 20  Find which host 
1820: 6b 65 79 20 62 65 6c 6f 6e 67 73 20 74 6f 0a 20  key belongs to. 
1830: 20 20 20 48 6f 73 74 20 68 6f 73 74 20 3d 20 48     Host host = H
1840: 6f 73 74 2e 77 68 69 63 68 48 6f 73 74 28 20 69  ost.whichHost( i
1850: 6e 74 4b 65 79 2c 20 6c 69 73 74 48 6f 73 74 73  ntKey, listHosts
1860: 20 29 3b 0a 0a 20 20 20 20 72 65 74 75 72 6e 20   );..    return 
1870: 68 6f 73 74 2e 67 65 74 48 6f 73 74 49 50 28 29  host.getHostIP()
1880: 3b 0a 20 20 7d 0a 0a 20 20 40 4f 76 65 72 72 69  ;.  }..  @Overri
1890: 64 65 0a 20 20 70 75 62 6c 69 63 20 76 6f 69 64  de.  public void
18a0: 20 63 6c 65 61 6e 75 70 28 29 20 74 68 72 6f 77   cleanup() throw
18b0: 73 20 44 42 45 78 63 65 70 74 69 6f 6e 20 7b 0a  s DBException {.
18c0: 0a 20 20 20 20 66 6f 72 28 20 45 6e 74 72 79 3c  .    for( Entry<
18d0: 53 74 72 69 6e 67 2c 20 4f 44 61 74 61 62 61 73  String, ODatabas
18e0: 65 44 6f 63 75 6d 65 6e 74 54 78 3e 20 65 6e 74  eDocumentTx> ent
18f0: 72 79 20 3a 20 64 61 74 61 62 61 73 65 73 2e 65  ry : databases.e
1900: 6e 74 72 79 53 65 74 28 29 20 29 0a 20 20 20 20  ntrySet() ).    
1910: 7b 0a 20 20 20 20 20 20 4f 44 61 74 61 62 61 73  {.      ODatabas
1920: 65 44 6f 63 75 6d 65 6e 74 54 78 20 64 61 74 61  eDocumentTx data
1930: 62 61 73 65 20 3d 20 65 6e 74 72 79 2e 67 65 74  base = entry.get
1940: 56 61 6c 75 65 28 29 3b 0a 20 20 20 20 20 20 0a  Value();.      .
1950: 20 20 20 20 20 20 69 66 28 20 64 61 74 61 62 61        if( databa
1960: 73 65 20 21 3d 20 6e 75 6c 6c 20 29 0a 20 20 20  se != null ).   
1970: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 64 61 74     {.        dat
1980: 61 62 61 73 65 2e 63 6c 6f 73 65 28 29 3b 0a 20  abase.close();. 
1990: 20 20 20 20 20 20 20 64 61 74 61 62 61 73 65 20         database 
19a0: 3d 20 6e 75 6c 6c 3b 0a 20 20 20 20 20 20 20 20  = null;.        
19b0: 65 6e 74 72 79 2e 73 65 74 56 61 6c 75 65 28 64  entry.setValue(d
19c0: 61 74 61 62 61 73 65 29 3b 0a 20 20 20 20 20 20  atabase);.      
19d0: 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 40  }.    }.  }..  @
19e0: 4f 76 65 72 72 69 64 65 0a 20 20 2f 2a 2a 0a 20  Override.  /**. 
19f0: 20 20 2a 20 49 6e 73 65 72 74 20 61 20 72 65 63    * Insert a rec
1a00: 6f 72 64 20 69 6e 20 74 68 65 20 64 61 74 61 62  ord in the datab
1a10: 61 73 65 2e 20 41 6e 79 20 66 69 65 6c 64 2f 76  ase. Any field/v
1a20: 61 6c 75 65 20 70 61 69 72 73 20 69 6e 20 74 68  alue pairs in th
1a30: 65 20 73 70 65 63 69 66 69 65 64 20 76 61 6c 75  e specified valu
1a40: 65 73 20 48 61 73 68 4d 61 70 20 77 69 6c 6c 20  es HashMap will 
1a50: 62 65 20 77 72 69 74 74 65 6e 20 69 6e 74 6f 20  be written into 
1a60: 74 68 65 20 72 65 63 6f 72 64 20 77 69 74 68 20  the record with 
1a70: 74 68 65 20 73 70 65 63 69 66 69 65 64 0a 20 20  the specified.  
1a80: 20 2a 20 72 65 63 6f 72 64 20 6b 65 79 2e 0a 20   * record key.. 
1a90: 20 20 2a 0a 20 20 20 2a 20 40 70 61 72 61 6d 20    *.   * @param 
1aa0: 74 61 62 6c 65 20 54 68 65 20 6e 61 6d 65 20 6f  table The name o
1ab0: 66 20 74 68 65 20 74 61 62 6c 65 0a 20 20 20 2a  f the table.   *
1ac0: 20 40 70 61 72 61 6d 20 6b 65 79 20 54 68 65 20   @param key The 
1ad0: 72 65 63 6f 72 64 20 6b 65 79 20 6f 66 20 74 68  record key of th
1ae0: 65 20 72 65 63 6f 72 64 20 74 6f 20 69 6e 73 65  e record to inse
1af0: 72 74 2e 0a 20 20 20 2a 20 40 70 61 72 61 6d 20  rt..   * @param 
1b00: 76 61 6c 75 65 73 20 41 20 48 61 73 68 4d 61 70  values A HashMap
1b10: 20 6f 66 20 66 69 65 6c 64 2f 76 61 6c 75 65 20   of field/value 
1b20: 70 61 69 72 73 20 74 6f 20 69 6e 73 65 72 74 20  pairs to insert 
1b30: 69 6e 20 74 68 65 20 72 65 63 6f 72 64 0a 20 20  in the record.  
1b40: 20 2a 20 40 72 65 74 75 72 6e 20 5a 65 72 6f 20   * @return Zero 
1b50: 6f 6e 20 73 75 63 63 65 73 73 2c 20 61 20 6e 6f  on success, a no
1b60: 6e 2d 7a 65 72 6f 20 65 72 72 6f 72 20 63 6f 64  n-zero error cod
1b70: 65 20 6f 6e 20 65 72 72 6f 72 2e 20 53 65 65 20  e on error. See 
1b80: 74 68 69 73 20 63 6c 61 73 73 27 73 20 64 65 73  this class's des
1b90: 63 72 69 70 74 69 6f 6e 20 66 6f 72 20 61 20 64  cription for a d
1ba0: 69 73 63 75 73 73 69 6f 6e 20 6f 66 20 65 72 72  iscussion of err
1bb0: 6f 72 20 63 6f 64 65 73 2e 0a 20 20 20 2a 2f 0a  or codes..   */.
1bc0: 20 20 70 75 62 6c 69 63 20 69 6e 74 20 69 6e 73    public int ins
1bd0: 65 72 74 28 53 74 72 69 6e 67 20 74 61 62 6c 65  ert(String table
1be0: 2c 20 53 74 72 69 6e 67 20 6b 65 79 2c 20 48 61  , String key, Ha
1bf0: 73 68 4d 61 70 3c 53 74 72 69 6e 67 2c 20 42 79  shMap<String, By
1c00: 74 65 49 74 65 72 61 74 6f 72 3e 20 76 61 6c 75  teIterator> valu
1c10: 65 73 29 20 7b 0a 0a 20 20 20 20 53 74 72 69 6e  es) {..    Strin
1c20: 67 20 68 6f 73 74 49 50 20 3d 20 66 69 6e 64 48  g hostIP = findH
1c30: 6f 73 74 28 6b 65 79 29 3b 0a 0a 20 20 20 20 74  ost(key);..    t
1c40: 72 79 20 7b 0a 0a 20 20 20 20 20 20 4f 44 61 74  ry {..      ODat
1c50: 61 62 61 73 65 44 6f 63 75 6d 65 6e 74 54 78 20  abaseDocumentTx 
1c60: 64 61 74 61 62 61 73 65 20 3d 20 64 61 74 61 62  database = datab
1c70: 61 73 65 73 2e 67 65 74 28 68 6f 73 74 49 50 29  ases.get(hostIP)
1c80: 3b 0a 0a 20 20 20 20 20 20 4f 44 61 74 61 62 61  ;..      ODataba
1c90: 73 65 52 65 63 6f 72 64 54 68 72 65 61 64 4c 6f  seRecordThreadLo
1ca0: 63 61 6c 2e 49 4e 53 54 41 4e 43 45 2e 73 65 74  cal.INSTANCE.set
1cb0: 28 64 61 74 61 62 61 73 65 29 3b 0a 0a 20 20 20  (database);..   
1cc0: 20 20 20 66 69 6e 61 6c 20 4f 44 6f 63 75 6d 65     final ODocume
1cd0: 6e 74 20 64 6f 63 75 6d 65 6e 74 20 3d 20 6e 65  nt document = ne
1ce0: 77 20 4f 44 6f 63 75 6d 65 6e 74 28 43 4c 41 53  w ODocument(CLAS
1cf0: 53 29 3b 0a 20 20 20 20 20 20 66 6f 72 20 28 45  S);.      for (E
1d00: 6e 74 72 79 3c 53 74 72 69 6e 67 2c 20 53 74 72  ntry<String, Str
1d10: 69 6e 67 3e 20 65 6e 74 72 79 20 3a 20 53 74 72  ing> entry : Str
1d20: 69 6e 67 42 79 74 65 49 74 65 72 61 74 6f 72 2e  ingByteIterator.
1d30: 67 65 74 53 74 72 69 6e 67 4d 61 70 28 76 61 6c  getStringMap(val
1d40: 75 65 73 29 2e 65 6e 74 72 79 53 65 74 28 29 29  ues).entrySet())
1d50: 0a 20 20 20 20 20 20 20 20 64 6f 63 75 6d 65 6e  .        documen
1d60: 74 2e 66 69 65 6c 64 28 65 6e 74 72 79 2e 67 65  t.field(entry.ge
1d70: 74 4b 65 79 28 29 2c 20 65 6e 74 72 79 2e 67 65  tKey(), entry.ge
1d80: 74 56 61 6c 75 65 28 29 29 3b 0a 20 20 20 20 20  tValue());.     
1d90: 20 64 6f 63 75 6d 65 6e 74 2e 73 61 76 65 28 29   document.save()
1da0: 3b 0a 20 20 20 20 20 20 64 69 63 74 69 6f 6e 61  ;.      dictiona
1db0: 72 69 65 73 2e 67 65 74 28 68 6f 73 74 49 50 29  ries.get(hostIP)
1dc0: 2e 70 75 74 28 6b 65 79 2c 20 64 6f 63 75 6d 65  .put(key, docume
1dd0: 6e 74 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75  nt);..      retu
1de0: 72 6e 20 30 3b 0a 20 20 20 20 7d 20 63 61 74 63  rn 0;.    } catc
1df0: 68 20 28 45 78 63 65 70 74 69 6f 6e 20 65 29 20  h (Exception e) 
1e00: 7b 0a 20 20 20 20 20 20 65 2e 70 72 69 6e 74 53  {.      e.printS
1e10: 74 61 63 6b 54 72 61 63 65 28 29 3b 0a 20 20 20  tackTrace();.   
1e20: 20 7d 0a 0a 20 20 20 20 72 65 74 75 72 6e 20 31   }..    return 1
1e30: 3b 0a 20 20 7d 0a 0a 20 20 40 4f 76 65 72 72 69  ;.  }..  @Overri
1e40: 64 65 0a 20 20 2f 2a 2a 0a 20 20 20 2a 20 44 65  de.  /**.   * De
1e50: 6c 65 74 65 20 61 20 72 65 63 6f 72 64 20 66 72  lete a record fr
1e60: 6f 6d 20 74 68 65 20 64 61 74 61 62 61 73 65 2e  om the database.
1e70: 0a 20 20 20 2a 0a 20 20 20 2a 20 40 70 61 72 61  .   *.   * @para
1e80: 6d 20 74 61 62 6c 65 20 54 68 65 20 6e 61 6d 65  m table The name
1e90: 20 6f 66 20 74 68 65 20 74 61 62 6c 65 0a 20 20   of the table.  
1ea0: 20 2a 20 40 70 61 72 61 6d 20 6b 65 79 20 54 68   * @param key Th
1eb0: 65 20 72 65 63 6f 72 64 20 6b 65 79 20 6f 66 20  e record key of 
1ec0: 74 68 65 20 72 65 63 6f 72 64 20 74 6f 20 64 65  the record to de
1ed0: 6c 65 74 65 2e 0a 20 20 20 2a 20 40 72 65 74 75  lete..   * @retu
1ee0: 72 6e 20 5a 65 72 6f 20 6f 6e 20 73 75 63 63 65  rn Zero on succe
1ef0: 73 73 2c 20 61 20 6e 6f 6e 2d 7a 65 72 6f 20 65  ss, a non-zero e
1f00: 72 72 6f 72 20 63 6f 64 65 20 6f 6e 20 65 72 72  rror code on err
1f10: 6f 72 2e 20 53 65 65 20 74 68 69 73 20 63 6c 61  or. See this cla
1f20: 73 73 27 73 20 64 65 73 63 72 69 70 74 69 6f 6e  ss's description
1f30: 20 66 6f 72 20 61 20 64 69 73 63 75 73 73 69 6f   for a discussio
1f40: 6e 20 6f 66 20 65 72 72 6f 72 20 63 6f 64 65 73  n of error codes
1f50: 2e 0a 20 20 20 2a 2f 0a 20 20 70 75 62 6c 69 63  ..   */.  public
1f60: 20 69 6e 74 20 64 65 6c 65 74 65 28 53 74 72 69   int delete(Stri
1f70: 6e 67 20 74 61 62 6c 65 2c 20 53 74 72 69 6e 67  ng table, String
1f80: 20 6b 65 79 29 20 7b 0a 20 20 20 20 74 72 79 20   key) {.    try 
1f90: 7b 0a 0a 20 20 20 20 20 20 53 74 72 69 6e 67 20  {..      String 
1fa0: 68 6f 73 74 49 50 20 3d 20 66 69 6e 64 48 6f 73  hostIP = findHos
1fb0: 74 28 6b 65 79 29 3b 0a 0a 20 20 20 20 20 20 64  t(key);..      d
1fc0: 69 63 74 69 6f 6e 61 72 69 65 73 2e 67 65 74 28  ictionaries.get(
1fd0: 68 6f 73 74 49 50 29 2e 72 65 6d 6f 76 65 28 6b  hostIP).remove(k
1fe0: 65 79 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75  ey);..      retu
1ff0: 72 6e 20 30 3b 0a 20 20 20 20 7d 20 63 61 74 63  rn 0;.    } catc
2000: 68 20 28 45 78 63 65 70 74 69 6f 6e 20 65 29 20  h (Exception e) 
2010: 7b 0a 20 20 20 20 20 20 65 2e 70 72 69 6e 74 53  {.      e.printS
2020: 74 61 63 6b 54 72 61 63 65 28 29 3b 0a 20 20 20  tackTrace();.   
2030: 20 7d 0a 20 20 20 20 72 65 74 75 72 6e 20 31 3b   }.    return 1;
2040: 0a 20 20 7d 0a 0a 20 20 40 4f 76 65 72 72 69 64  .  }..  @Overrid
2050: 65 0a 20 20 2f 2a 2a 0a 20 20 20 2a 20 52 65 61  e.  /**.   * Rea
2060: 64 20 61 20 72 65 63 6f 72 64 20 66 72 6f 6d 20  d a record from 
2070: 74 68 65 20 64 61 74 61 62 61 73 65 2e 20 45 61  the database. Ea
2080: 63 68 20 66 69 65 6c 64 2f 76 61 6c 75 65 20 70  ch field/value p
2090: 61 69 72 20 66 72 6f 6d 20 74 68 65 20 72 65 73  air from the res
20a0: 75 6c 74 20 77 69 6c 6c 20 62 65 20 73 74 6f 72  ult will be stor
20b0: 65 64 20 69 6e 20 61 20 48 61 73 68 4d 61 70 2e  ed in a HashMap.
20c0: 0a 20 20 20 2a 0a 20 20 20 2a 20 40 70 61 72 61  .   *.   * @para
20d0: 6d 20 74 61 62 6c 65 20 54 68 65 20 6e 61 6d 65  m table The name
20e0: 20 6f 66 20 74 68 65 20 74 61 62 6c 65 0a 20 20   of the table.  
20f0: 20 2a 20 40 70 61 72 61 6d 20 6b 65 79 20 54 68   * @param key Th
2100: 65 20 72 65 63 6f 72 64 20 6b 65 79 20 6f 66 20  e record key of 
2110: 74 68 65 20 72 65 63 6f 72 64 20 74 6f 20 72 65  the record to re
2120: 61 64 2e 0a 20 20 20 2a 20 40 70 61 72 61 6d 20  ad..   * @param 
2130: 66 69 65 6c 64 73 20 54 68 65 20 6c 69 73 74 20  fields The list 
2140: 6f 66 20 66 69 65 6c 64 73 20 74 6f 20 72 65 61  of fields to rea
2150: 64 2c 20 6f 72 20 6e 75 6c 6c 20 66 6f 72 20 61  d, or null for a
2160: 6c 6c 20 6f 66 20 74 68 65 6d 0a 20 20 20 2a 20  ll of them.   * 
2170: 40 70 61 72 61 6d 20 72 65 73 75 6c 74 20 41 20  @param result A 
2180: 48 61 73 68 4d 61 70 20 6f 66 20 66 69 65 6c 64  HashMap of field
2190: 2f 76 61 6c 75 65 20 70 61 69 72 73 20 66 6f 72  /value pairs for
21a0: 20 74 68 65 20 72 65 73 75 6c 74 0a 20 20 20 2a   the result.   *
21b0: 20 40 72 65 74 75 72 6e 20 5a 65 72 6f 20 6f 6e   @return Zero on
21c0: 20 73 75 63 63 65 73 73 2c 20 61 20 6e 6f 6e 2d   success, a non-
21d0: 7a 65 72 6f 20 65 72 72 6f 72 20 63 6f 64 65 20  zero error code 
21e0: 6f 6e 20 65 72 72 6f 72 20 6f 72 20 22 6e 6f 74  on error or "not
21f0: 20 66 6f 75 6e 64 22 2e 0a 20 20 20 2a 2f 0a 20   found"..   */. 
2200: 20 70 75 62 6c 69 63 20 69 6e 74 20 72 65 61 64   public int read
2210: 28 53 74 72 69 6e 67 20 74 61 62 6c 65 2c 20 53  (String table, S
2220: 74 72 69 6e 67 20 6b 65 79 2c 20 53 65 74 3c 53  tring key, Set<S
2230: 74 72 69 6e 67 3e 20 66 69 65 6c 64 73 2c 20 48  tring> fields, H
2240: 61 73 68 4d 61 70 3c 53 74 72 69 6e 67 2c 20 42  ashMap<String, B
2250: 79 74 65 49 74 65 72 61 74 6f 72 3e 20 72 65 73  yteIterator> res
2260: 75 6c 74 29 20 7b 0a 20 20 20 20 74 72 79 20 7b  ult) {.    try {
2270: 0a 20 20 20 20 20 20 0a 20 20 20 20 20 20 53 74  .      .      St
2280: 72 69 6e 67 20 68 6f 73 74 49 50 20 3d 20 66 69  ring hostIP = fi
2290: 6e 64 48 6f 73 74 28 6b 65 79 29 3b 0a 0a 20 20  ndHost(key);..  
22a0: 20 20 20 20 66 69 6e 61 6c 20 4f 44 6f 63 75 6d      final ODocum
22b0: 65 6e 74 20 64 6f 63 75 6d 65 6e 74 20 3d 20 64  ent document = d
22c0: 69 63 74 69 6f 6e 61 72 69 65 73 2e 67 65 74 28  ictionaries.get(
22d0: 68 6f 73 74 49 50 29 2e 67 65 74 28 6b 65 79 29  hostIP).get(key)
22e0: 3b 0a 20 20 20 20 20 20 69 66 20 28 64 6f 63 75  ;.      if (docu
22f0: 6d 65 6e 74 20 21 3d 20 6e 75 6c 6c 29 20 7b 0a  ment != null) {.
2300: 20 20 20 20 20 20 20 20 69 66 20 28 66 69 65 6c          if (fiel
2310: 64 73 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20  ds != null).    
2320: 20 20 20 20 20 20 66 6f 72 20 28 53 74 72 69 6e        for (Strin
2330: 67 20 66 69 65 6c 64 20 3a 20 66 69 65 6c 64 73  g field : fields
2340: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ).            re
2350: 73 75 6c 74 2e 70 75 74 28 66 69 65 6c 64 2c 20  sult.put(field, 
2360: 6e 65 77 20 53 74 72 69 6e 67 42 79 74 65 49 74  new StringByteIt
2370: 65 72 61 74 6f 72 28 28 53 74 72 69 6e 67 29 20  erator((String) 
2380: 64 6f 63 75 6d 65 6e 74 2e 66 69 65 6c 64 28 66  document.field(f
2390: 69 65 6c 64 29 29 29 3b 0a 20 20 20 20 20 20 20  ield)));.       
23a0: 20 20 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20     else.        
23b0: 20 20 20 20 66 6f 72 20 28 53 74 72 69 6e 67 20      for (String 
23c0: 66 69 65 6c 64 20 3a 20 64 6f 63 75 6d 65 6e 74  field : document
23d0: 2e 66 69 65 6c 64 4e 61 6d 65 73 28 29 29 0a 20  .fieldNames()). 
23e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 73               res
23f0: 75 6c 74 2e 70 75 74 28 66 69 65 6c 64 2c 20 6e  ult.put(field, n
2400: 65 77 20 53 74 72 69 6e 67 42 79 74 65 49 74 65  ew StringByteIte
2410: 72 61 74 6f 72 28 28 53 74 72 69 6e 67 29 20 64  rator((String) d
2420: 6f 63 75 6d 65 6e 74 2e 66 69 65 6c 64 28 66 69  ocument.field(fi
2430: 65 6c 64 29 29 29 3b 0a 20 20 20 20 20 20 20 20  eld)));.        
2440: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
2450: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
2460: 20 20 7d 20 63 61 74 63 68 20 28 45 78 63 65 70    } catch (Excep
2470: 74 69 6f 6e 20 65 29 20 7b 0a 20 20 20 20 20 20  tion e) {.      
2480: 20 20 20 20 65 2e 70 72 69 6e 74 53 74 61 63 6b      e.printStack
2490: 54 72 61 63 65 28 29 3b 0a 20 20 20 20 20 20 20  Trace();.       
24a0: 20 7d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72   }.        retur
24b0: 6e 20 31 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20  n 1;.      }..  
24c0: 20 20 20 20 40 4f 76 65 72 72 69 64 65 0a 20 20      @Override.  
24d0: 2f 2a 2a 0a 20 20 20 2a 20 55 70 64 61 74 65 20  /**.   * Update 
24e0: 61 20 72 65 63 6f 72 64 20 69 6e 20 74 68 65 20  a record in the 
24f0: 64 61 74 61 62 61 73 65 2e 20 41 6e 79 20 66 69  database. Any fi
2500: 65 6c 64 2f 76 61 6c 75 65 20 70 61 69 72 73 20  eld/value pairs 
2510: 69 6e 20 74 68 65 20 73 70 65 63 69 66 69 65 64  in the specified
2520: 20 76 61 6c 75 65 73 20 48 61 73 68 4d 61 70 20   values HashMap 
2530: 77 69 6c 6c 20 62 65 20 77 72 69 74 74 65 6e 20  will be written 
2540: 69 6e 74 6f 20 74 68 65 20 72 65 63 6f 72 64 20  into the record 
2550: 77 69 74 68 20 74 68 65 20 73 70 65 63 69 66 69  with the specifi
2560: 65 64 0a 20 20 20 2a 20 72 65 63 6f 72 64 20 6b  ed.   * record k
2570: 65 79 2c 20 6f 76 65 72 77 72 69 74 69 6e 67 20  ey, overwriting 
2580: 61 6e 79 20 65 78 69 73 74 69 6e 67 20 76 61 6c  any existing val
2590: 75 65 73 20 77 69 74 68 20 74 68 65 20 73 61 6d  ues with the sam
25a0: 65 20 66 69 65 6c 64 20 6e 61 6d 65 2e 0a 20 20  e field name..  
25b0: 20 2a 0a 20 20 20 2a 20 40 70 61 72 61 6d 20 74   *.   * @param t
25c0: 61 62 6c 65 20 54 68 65 20 6e 61 6d 65 20 6f 66  able The name of
25d0: 20 74 68 65 20 74 61 62 6c 65 0a 20 20 20 2a 20   the table.   * 
25e0: 40 70 61 72 61 6d 20 6b 65 79 20 54 68 65 20 72  @param key The r
25f0: 65 63 6f 72 64 20 6b 65 79 20 6f 66 20 74 68 65  ecord key of the
2600: 20 72 65 63 6f 72 64 20 74 6f 20 77 72 69 74 65   record to write
2610: 2e 0a 20 20 20 2a 20 40 70 61 72 61 6d 20 76 61  ..   * @param va
2620: 6c 75 65 73 20 41 20 48 61 73 68 4d 61 70 20 6f  lues A HashMap o
2630: 66 20 66 69 65 6c 64 2f 76 61 6c 75 65 20 70 61  f field/value pa
2640: 69 72 73 20 74 6f 20 75 70 64 61 74 65 20 69 6e  irs to update in
2650: 20 74 68 65 20 72 65 63 6f 72 64 0a 20 20 20 2a   the record.   *
2660: 20 40 72 65 74 75 72 6e 20 5a 65 72 6f 20 6f 6e   @return Zero on
2670: 20 73 75 63 63 65 73 73 2c 20 61 20 6e 6f 6e 2d   success, a non-
2680: 7a 65 72 6f 20 65 72 72 6f 72 20 63 6f 64 65 20  zero error code 
2690: 6f 6e 20 65 72 72 6f 72 2e 20 53 65 65 20 74 68  on error. See th
26a0: 69 73 20 63 6c 61 73 73 27 73 20 64 65 73 63 72  is class's descr
26b0: 69 70 74 69 6f 6e 20 66 6f 72 20 61 20 64 69 73  iption for a dis
26c0: 63 75 73 73 69 6f 6e 20 6f 66 20 65 72 72 6f 72  cussion of error
26d0: 20 63 6f 64 65 73 2e 0a 20 20 20 2a 2f 0a 20 20   codes..   */.  
26e0: 70 75 62 6c 69 63 20 69 6e 74 20 75 70 64 61 74  public int updat
26f0: 65 28 53 74 72 69 6e 67 20 74 61 62 6c 65 2c 20  e(String table, 
2700: 53 74 72 69 6e 67 20 6b 65 79 2c 20 48 61 73 68  String key, Hash
2710: 4d 61 70 3c 53 74 72 69 6e 67 2c 20 42 79 74 65  Map<String, Byte
2720: 49 74 65 72 61 74 6f 72 3e 20 76 61 6c 75 65 73  Iterator> values
2730: 29 20 7b 0a 20 20 20 20 74 72 79 20 7b 0a 20 20  ) {.    try {.  
2740: 20 20 20 20 0a 20 20 20 20 20 20 53 74 72 69 6e      .      Strin
2750: 67 20 68 6f 73 74 49 50 20 3d 20 66 69 6e 64 48  g hostIP = findH
2760: 6f 73 74 28 6b 65 79 29 3b 0a 0a 20 20 20 20 20  ost(key);..     
2770: 20 4f 44 61 74 61 62 61 73 65 44 6f 63 75 6d 65   ODatabaseDocume
2780: 6e 74 54 78 20 64 61 74 61 62 61 73 65 20 3d 20  ntTx database = 
2790: 64 61 74 61 62 61 73 65 73 2e 67 65 74 28 68 6f  databases.get(ho
27a0: 73 74 49 50 29 3b 0a 0a 20 20 20 20 20 20 4f 44  stIP);..      OD
27b0: 61 74 61 62 61 73 65 52 65 63 6f 72 64 54 68 72  atabaseRecordThr
27c0: 65 61 64 4c 6f 63 61 6c 2e 49 4e 53 54 41 4e 43  eadLocal.INSTANC
27d0: 45 2e 73 65 74 28 64 61 74 61 62 61 73 65 29 3b  E.set(database);
27e0: 0a 0a 20 20 20 20 20 20 66 69 6e 61 6c 20 4f 44  ..      final OD
27f0: 6f 63 75 6d 65 6e 74 20 64 6f 63 75 6d 65 6e 74  ocument document
2800: 20 3d 20 64 69 63 74 69 6f 6e 61 72 69 65 73 2e   = dictionaries.
2810: 67 65 74 28 68 6f 73 74 49 50 29 2e 67 65 74 28  get(hostIP).get(
2820: 6b 65 79 29 3b 0a 20 20 20 20 20 20 69 66 20 28  key);.      if (
2830: 64 6f 63 75 6d 65 6e 74 20 21 3d 20 6e 75 6c 6c  document != null
2840: 29 20 7b 0a 20 20 20 20 20 20 20 20 66 6f 72 20  ) {.        for 
2850: 28 45 6e 74 72 79 3c 53 74 72 69 6e 67 2c 20 53  (Entry<String, S
2860: 74 72 69 6e 67 3e 20 65 6e 74 72 79 20 3a 20 53  tring> entry : S
2870: 74 72 69 6e 67 42 79 74 65 49 74 65 72 61 74 6f  tringByteIterato
2880: 72 2e 67 65 74 53 74 72 69 6e 67 4d 61 70 28 76  r.getStringMap(v
2890: 61 6c 75 65 73 29 2e 65 6e 74 72 79 53 65 74 28  alues).entrySet(
28a0: 29 29 0a 20 20 20 20 20 20 20 20 20 20 64 6f 63  )).          doc
28b0: 75 6d 65 6e 74 2e 66 69 65 6c 64 28 65 6e 74 72  ument.field(entr
28c0: 79 2e 67 65 74 4b 65 79 28 29 2c 20 65 6e 74 72  y.getKey(), entr
28d0: 79 2e 67 65 74 56 61 6c 75 65 28 29 29 3b 0a 20  y.getValue());. 
28e0: 20 20 20 20 20 20 20 64 6f 63 75 6d 65 6e 74 2e         document.
28f0: 73 61 76 65 28 29 3b 0a 20 20 20 20 20 20 20 20  save();.        
2900: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20  return 0;.      
2910: 7d 0a 20 20 20 20 7d 20 63 61 74 63 68 20 28 45  }.    } catch (E
2920: 78 63 65 70 74 69 6f 6e 20 65 29 20 7b 0a 20 20  xception e) {.  
2930: 20 20 20 20 65 2e 70 72 69 6e 74 53 74 61 63 6b      e.printStack
2940: 54 72 61 63 65 28 29 3b 0a 20 20 20 20 7d 0a 20  Trace();.    }. 
2950: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 7d     return 1;.  }
2960: 0a 0a 20 20 40 4f 76 65 72 72 69 64 65 0a 20 20  ..  @Override.  
2970: 2f 2a 2a 0a 20 20 20 2a 20 50 65 72 66 6f 72 6d  /**.   * Perform
2980: 20 61 20 72 61 6e 67 65 20 73 63 61 6e 20 66 6f   a range scan fo
2990: 72 20 61 20 73 65 74 20 6f 66 20 72 65 63 6f 72  r a set of recor
29a0: 64 73 20 69 6e 20 74 68 65 20 64 61 74 61 62 61  ds in the databa
29b0: 73 65 2e 20 45 61 63 68 20 66 69 65 6c 64 2f 76  se. Each field/v
29c0: 61 6c 75 65 20 70 61 69 72 20 66 72 6f 6d 20 74  alue pair from t
29d0: 68 65 20 72 65 73 75 6c 74 20 77 69 6c 6c 20 62  he result will b
29e0: 65 20 73 74 6f 72 65 64 20 69 6e 20 61 20 48 61  e stored in a Ha
29f0: 73 68 4d 61 70 2e 0a 20 20 20 2a 0a 20 20 20 2a  shMap..   *.   *
2a00: 20 40 70 61 72 61 6d 20 74 61 62 6c 65 20 54 68   @param table Th
2a10: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 61  e name of the ta
2a20: 62 6c 65 0a 20 20 20 2a 20 40 70 61 72 61 6d 20  ble.   * @param 
2a30: 73 74 61 72 74 6b 65 79 20 54 68 65 20 72 65 63  startkey The rec
2a40: 6f 72 64 20 6b 65 79 20 6f 66 20 74 68 65 20 66  ord key of the f
2a50: 69 72 73 74 20 72 65 63 6f 72 64 20 74 6f 20 72  irst record to r
2a60: 65 61 64 2e 0a 20 20 20 2a 20 40 70 61 72 61 6d  ead..   * @param
2a70: 20 72 65 63 6f 72 64 63 6f 75 6e 74 20 54 68 65   recordcount The
2a80: 20 6e 75 6d 62 65 72 20 6f 66 20 72 65 63 6f 72   number of recor
2a90: 64 73 20 74 6f 20 72 65 61 64 0a 20 20 20 2a 20  ds to read.   * 
2aa0: 40 70 61 72 61 6d 20 66 69 65 6c 64 73 20 54 68  @param fields Th
2ab0: 65 20 6c 69 73 74 20 6f 66 20 66 69 65 6c 64 73  e list of fields
2ac0: 20 74 6f 20 72 65 61 64 2c 20 6f 72 20 6e 75 6c   to read, or nul
2ad0: 6c 20 66 6f 72 20 61 6c 6c 20 6f 66 20 74 68 65  l for all of the
2ae0: 6d 0a 20 20 20 2a 20 40 70 61 72 61 6d 20 72 65  m.   * @param re
2af0: 73 75 6c 74 20 41 20 56 65 63 74 6f 72 20 6f 66  sult A Vector of
2b00: 20 48 61 73 68 4d 61 70 73 2c 20 77 68 65 72 65   HashMaps, where
2b10: 20 65 61 63 68 20 48 61 73 68 4d 61 70 20 69 73   each HashMap is
2b20: 20 61 20 73 65 74 20 66 69 65 6c 64 2f 76 61 6c   a set field/val
2b30: 75 65 20 70 61 69 72 73 20 66 6f 72 20 6f 6e 65  ue pairs for one
2b40: 20 72 65 63 6f 72 64 0a 20 20 20 2a 20 40 72 65   record.   * @re
2b50: 74 75 72 6e 20 5a 65 72 6f 20 6f 6e 20 73 75 63  turn Zero on suc
2b60: 63 65 73 73 2c 20 61 20 6e 6f 6e 2d 7a 65 72 6f  cess, a non-zero
2b70: 20 65 72 72 6f 72 20 63 6f 64 65 20 6f 6e 20 65   error code on e
2b80: 72 72 6f 72 2e 20 53 65 65 20 74 68 69 73 20 63  rror. See this c
2b90: 6c 61 73 73 27 73 20 64 65 73 63 72 69 70 74 69  lass's descripti
2ba0: 6f 6e 20 66 6f 72 20 61 20 64 69 73 63 75 73 73  on for a discuss
2bb0: 69 6f 6e 20 6f 66 20 65 72 72 6f 72 20 63 6f 64  ion of error cod
2bc0: 65 73 2e 0a 20 20 20 2a 2f 0a 20 20 70 75 62 6c  es..   */.  publ
2bd0: 69 63 20 69 6e 74 20 73 63 61 6e 28 53 74 72 69  ic int scan(Stri
2be0: 6e 67 20 74 61 62 6c 65 2c 20 53 74 72 69 6e 67  ng table, String
2bf0: 20 73 74 61 72 74 6b 65 79 2c 20 69 6e 74 20 72   startkey, int r
2c00: 65 63 6f 72 64 63 6f 75 6e 74 2c 20 53 65 74 3c  ecordcount, Set<
2c10: 53 74 72 69 6e 67 3e 20 66 69 65 6c 64 73 2c 20  String> fields, 
2c20: 56 65 63 74 6f 72 3c 48 61 73 68 4d 61 70 3c 53  Vector<HashMap<S
2c30: 74 72 69 6e 67 2c 20 42 79 74 65 49 74 65 72 61  tring, ByteItera
2c40: 74 6f 72 3e 3e 20 72 65 73 75 6c 74 29 20 7b 0a  tor>> result) {.
2c50: 20 20 20 20 74 72 79 20 7b 0a 20 20 20 20 20 20      try {.      
2c60: 66 69 6e 61 6c 20 43 6f 6c 6c 65 63 74 69 6f 6e  final Collection
2c70: 3c 4f 44 6f 63 75 6d 65 6e 74 3e 20 64 6f 63 75  <ODocument> docu
2c80: 6d 65 6e 74 73 20 3d 20 64 69 63 74 69 6f 6e 61  ments = dictiona
2c90: 72 79 2e 67 65 74 49 6e 64 65 78 28 29 2e 67 65  ry.getIndex().ge
2ca0: 74 45 6e 74 72 69 65 73 4d 61 6a 6f 72 28 73 74  tEntriesMajor(st
2cb0: 61 72 74 6b 65 79 2c 20 74 72 75 65 2c 20 72 65  artkey, true, re
2cc0: 63 6f 72 64 63 6f 75 6e 74 29 3b 0a 20 20 20 20  cordcount);.    
2cd0: 20 20 66 6f 72 20 28 4f 44 6f 63 75 6d 65 6e 74    for (ODocument
2ce0: 20 64 6f 63 75 6d 65 6e 74 20 3a 20 64 6f 63 75   document : docu
2cf0: 6d 65 6e 74 73 29 20 7b 0a 20 20 20 20 20 20 20  ments) {.       
2d00: 20 66 69 6e 61 6c 20 48 61 73 68 4d 61 70 3c 53   final HashMap<S
2d10: 74 72 69 6e 67 2c 20 42 79 74 65 49 74 65 72 61  tring, ByteItera
2d20: 74 6f 72 3e 20 65 6e 74 72 79 20 3d 20 6e 65 77  tor> entry = new
2d30: 20 48 61 73 68 4d 61 70 3c 53 74 72 69 6e 67 2c   HashMap<String,
2d40: 20 42 79 74 65 49 74 65 72 61 74 6f 72 3e 28 66   ByteIterator>(f
2d50: 69 65 6c 64 73 2e 73 69 7a 65 28 29 29 3b 0a 20  ields.size());. 
2d60: 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e 61 64         result.ad
2d70: 64 28 65 6e 74 72 79 29 3b 0a 0a 20 20 20 20 20  d(entry);..     
2d80: 20 20 20 66 6f 72 20 28 53 74 72 69 6e 67 20 66     for (String f
2d90: 69 65 6c 64 20 3a 20 66 69 65 6c 64 73 29 0a 20  ield : fields). 
2da0: 20 20 20 20 20 20 20 20 20 65 6e 74 72 79 2e 70           entry.p
2db0: 75 74 28 66 69 65 6c 64 2c 20 6e 65 77 20 53 74  ut(field, new St
2dc0: 72 69 6e 67 42 79 74 65 49 74 65 72 61 74 6f 72  ringByteIterator
2dd0: 28 28 53 74 72 69 6e 67 29 20 64 6f 63 75 6d 65  ((String) docume
2de0: 6e 74 2e 66 69 65 6c 64 28 66 69 65 6c 64 29 29  nt.field(field))
2df0: 29 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  );.      }..    
2e00: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20    return 0;.    
2e10: 7d 20 63 61 74 63 68 20 28 45 78 63 65 70 74 69  } catch (Excepti
2e20: 6f 6e 20 65 29 20 7b 0a 20 20 20 20 20 20 65 2e  on e) {.      e.
2e30: 70 72 69 6e 74 53 74 61 63 6b 54 72 61 63 65 28  printStackTrace(
2e40: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74  );.    }.    ret
2e50: 75 72 6e 20 31 3b 0a 20 20 7d 0a 7d 0a 0a        urn 1;.  }.}..