4 char name
[196] = "PRABAKARAN";
5 int select(Table
*table
, ComparisionOp op
)
7 printf("Operator test for %d\n", op
);
10 p1
.setTerm("f1", op
, &val1
);
11 table
->setCondition(&p1
);
14 while ((tuple
= (char*) table
->fetch())) {
15 printf("tuple value is %d %s \n", id
, name
);
25 DbRetVal rv
= conn
.open("praba", "manager");
28 printf("Error during connection %d\n", rv
);
31 DatabaseManager
*dbMgr
= conn
.getDatabaseManager();
32 if (dbMgr
== NULL
) { printf("Auth failed\n"); return 2;}
34 tabDef
.addField("f1", typeInt
, 0, NULL
, true, true );
35 tabDef
.addField("f2", typeString
, 196);
36 rv
= dbMgr
->createTable("t1", tabDef
);
37 if (rv
!= OK
) { printf("Table creation failed\n"); return 3; }
38 printf("Table created\n");
40 HashIndexInitInfo
*idxInfo
= new HashIndexInitInfo();
41 strcpy(idxInfo
->tableName
, "t1");
42 idxInfo
->list
.append("f1");
43 idxInfo
->indType
= hashIndex
;
44 rv
= dbMgr
->createIndex("indx1", idxInfo
);
45 if (rv
!= OK
) { printf("Index creation failed\n"); return -1; }
46 printf("Index created\n");
48 Table
*table
= dbMgr
->openTable("t1");
49 if (table
== NULL
) { printf("Unable to open table\n"); return 4; }
50 table
->bindFld("f1", &id
);
51 table
->bindFld("f2", name
);
55 rv
=conn
.startTransaction();
58 if (rv
!= OK
) exit(5);
60 strcpy(name
, "PRABAKARAN0123456750590");
61 ret
= table
->insertTuple();
66 conn
.startTransaction();
67 select(table
, OpEquals
);
70 conn
.startTransaction();
71 select(table
, OpNotEquals
);
74 conn
.startTransaction();
75 select(table
, OpLessThan
);
78 conn
.startTransaction();
79 select( table
, OpLessThanEquals
);
82 conn
.startTransaction();
83 select( table
, OpGreaterThan
);
86 conn
.startTransaction();
87 select( table
, OpGreaterThanEquals
);
92 p1
.setTerm("f1", OpEquals
, &val1
);
93 table
->setCondition(&p1
);
94 rv
= conn
.startTransaction();
97 if (rv
!= OK
) exit (1);
100 tuple
= (char*)table
->fetch() ;
101 if (tuple
== NULL
) {printf("loop break in %d\n", i
);table
->close();break;}
102 strcpy(name
, "PRABAKARAN0950576543210");
103 table
->updateTuple();
107 rv
= conn
.startTransaction();
108 for(i
= 0; i
< 5; i
++)
110 if (rv
!= OK
) exit (1);
113 tuple
= (char*)table
->fetch() ;
114 if (tuple
== NULL
) {printf("loop break in %d\n", i
);table
->close();break;}
115 printf("deleting tuple %d %s \n", id
, name
);
116 table
->deleteTuple();
121 table
->setCondition(NULL
);
122 rv
= conn
.startTransaction();
124 while ((tuple
= (char*) table
->fetch())) {
125 printf("after delete tuple present. Its value is %d %s \n", id
, name
);
131 dbMgr
->closeTable(table
);
132 dbMgr
->dropTable("t1");