radare2/libr/db
pancake 3b65f42167 Update sdb to 0.5, sdb is now public api
Update pkgconfig files
sdb now supports json and cas operations
sync pair.c to use the new cas api
2012-09-04 01:46:12 +02:00
..
sdb Update sdb to 0.5, sdb is now public api 2012-09-04 01:46:12 +02:00
t Fix android build and add r_core->anal_define api 2012-09-03 01:27:52 +02:00
db.c * Fix build (missing R_ANAL_BB_HAS_OPS somewhere) 2011-11-15 14:30:52 +01:00
Makefile Update sdb to 0.5, sdb is now public api 2012-09-04 01:46:12 +02:00
pair.c Update sdb to 0.5, sdb is now public api 2012-09-04 01:46:12 +02:00
r.mk Fix android build and add r_core->anal_define api 2012-09-03 01:27:52 +02:00
README * Added r_db_delete() method in r_db api 2009-06-18 13:10:26 +00:00
table.c * Fix android blob build 2012-04-01 01:40:04 +02:00
TODO * Initial import of the hashtable implementation of WayLand 2011-03-17 19:05:39 +01:00

+------+
| r.db | Simple and performance-friendly relational database
+------+

The database of r.db is based on index tables of key-size depth.
The key is the index of the key-bucket array which opens the search
space to a single key.

Items are directly sorted

  [255] key buckets
    |
    `-> [0..255]           -----.
         |     \                |
         |      \               |
     [0..255]  [0..255]         |
         |        |             |-- size of key (depth)
     [0..255]    ...            |
         |                      |
     [0..255]              -----'

OPERATIONS
==========

   ADD

   DELETE

     r_db_delete_by_key(db, K_ID, &tmp) # specify more than one key?

   ITERATE
   

+----------+
| r.db.sql | The SQL frontend for r.db
+----------+

 - Compiles simple SQL-like sentences into a set of r.db queries

void **iter = r_db_sql_query("select * from flags");
while(r_db_ptr(iter)) {
	struct foo_t *foo = r_db_ptr(iter);
	iter = r_db_ptr_next(iter);
}