Class: LMDB::Cursor
- Inherits:
-
Object
- Object
- LMDB::Cursor
- Defined in:
- ext/lmdb_ext/lmdb_ext.c,
ext/lmdb_ext/lmdb_ext.c
Overview
A Cursor points to records in a database, and is used to iterate through the records in the database.
Cursors are created in the context of a transaction, and should only be used as long as that transaction is active. In other words, after you Transaction#commit or Transaction#abort a transaction, the cursors created while that transaction was active are no longer usable.
To create a cursor, call Database#cursor and pass it a block for that should be performed using the cursor.
Instance Method Summary collapse
-
#close ⇒ Object
Close a cursor.
-
#count ⇒ Number
Return count of duplicates for current key.
- #cursor_db ⇒ Database
-
#delete(options) ⇒ Object
Delete current key/data pair.
-
#first ⇒ Array?
Position the cursor to the first record in the database, and return its value.
-
#get ⇒ Array
Return the value of the record to which the cursor points.
-
#last ⇒ Array?
Position the cursor to the last record in the database, and return its value.
-
#next(nodup = nil) ⇒ Array?
Position the cursor to the next record in the database, and return its value.
-
#next_range ⇒ Array?
Position the cursor to the next record in the database, and return its value if the record’s key is less than or equal to the specified key, or nil otherwise.
-
#prev ⇒ Array?
Position the cursor to the previous record in the database, and return its value.
-
#put(key, value, options) ⇒ Object
Store by cursor.
-
#set(key, value = nil) ⇒ Array
Set the cursor to a specified key, optionally at the specified value if the database was opened with
:dupsort. -
#set_range(key) ⇒ Array
Set the cursor at the first key greater than or equal to a specified key.
Instance Method Details
#close ⇒ Object
1166 1167 1168 1169 1170 1171 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1166 static VALUE cursor_close(VALUE self) { CURSOR(self, cursor); mdb_cursor_close(cursor->cur); cursor->cur = 0; return Qnil; } |
#count ⇒ Number
1541 1542 1543 1544 1545 1546 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1541 static VALUE cursor_count(VALUE self) { CURSOR(self, cursor); size_t count; check(mdb_cursor_count(cursor->cur, &count)); return SIZET2NUM(count); } |
#cursor_db ⇒ Database
1529 1530 1531 1532 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1529 static VALUE cursor_db(VALUE self) { CURSOR(self, cursor); return cursor->db; } |
#delete(options) ⇒ Object
1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1505 static VALUE cursor_delete(int argc, VALUE *argv, VALUE self) { CURSOR(self, cursor); VALUE option_hash; #ifdef RB_SCAN_ARGS_KEYWORDS rb_scan_args_kw(RB_SCAN_ARGS_LAST_HASH_KEYWORDS, argc, argv, ":", &option_hash); #else rb_scan_args(argc, argv, ":", &option_hash); #endif int flags = 0; if (!NIL_P(option_hash)) rb_hash_foreach(option_hash, (int (*)(ANYARGS))cursor_delete_flags, (VALUE)&flags); check(mdb_cursor_del(cursor->cur, flags)); return Qnil; } |
#first ⇒ Array?
1247 1248 1249 1250 1251 1252 1253 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1247 static VALUE cursor_first(VALUE self) { CURSOR(self, cursor); MDB_val key, value; check(mdb_cursor_get(cursor->cur, &key, &value, MDB_FIRST)); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#get ⇒ Array
1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1414 static VALUE cursor_get(VALUE self) { CURSOR(self, cursor); MDB_val key, value; int ret = mdb_cursor_get(cursor->cur, &key, &value, MDB_GET_CURRENT); if (ret == MDB_NOTFOUND) return Qnil; check(ret); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#last ⇒ Array?
1262 1263 1264 1265 1266 1267 1268 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1262 static VALUE cursor_last(VALUE self) { CURSOR(self, cursor); MDB_val key, value; check(mdb_cursor_get(cursor->cur, &key, &value, MDB_LAST)); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#next(nodup = nil) ⇒ Array?
1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1296 static VALUE cursor_next(int argc, VALUE* argv, VALUE self) { CURSOR(self, cursor); VALUE nodup; MDB_val key, value; MDB_cursor_op op = MDB_NEXT; rb_scan_args(argc, argv, "01", &nodup); if (RTEST(nodup)) op = MDB_NEXT_NODUP; int ret = mdb_cursor_get(cursor->cur, &key, &value, op); if (ret == MDB_NOTFOUND) return Qnil; check(ret); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#next_range ⇒ Array?
1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1324 static VALUE cursor_next_range(VALUE self, VALUE upper_bound_key) { CURSOR(self, cursor); MDB_val key, value, ub_key; int ret = mdb_cursor_get(cursor->cur, &key, &value, MDB_NEXT); if (ret == MDB_NOTFOUND) return Qnil; check(ret); ub_key.mv_size = RSTRING_LEN(upper_bound_key); ub_key.mv_data = StringValuePtr(upper_bound_key); MDB_txn* txn = mdb_cursor_txn(cursor->cur); MDB_dbi dbi = mdb_cursor_dbi(cursor->cur); if (mdb_cmp(txn, dbi, &key, &ub_key) <= 0) { return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } else { return Qnil; } } |
#prev ⇒ Array?
1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1277 static VALUE cursor_prev(VALUE self) { CURSOR(self, cursor); MDB_val key, value; int ret = mdb_cursor_get(cursor->cur, &key, &value, MDB_PREV); if (ret == MDB_NOTFOUND) return Qnil; check(ret); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#put(key, value, options) ⇒ Object
1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1462 static VALUE cursor_put(int argc, VALUE* argv, VALUE self) { CURSOR(self, cursor); VALUE vkey, vval, option_hash; #ifdef RB_SCAN_ARGS_KEYWORDS rb_scan_args_kw(RB_SCAN_ARGS_LAST_HASH_KEYWORDS, argc, argv, "2:", &vkey, &vval, &option_hash); #else rb_scan_args(argc, argv, "2:", &vkey, &vval, &option_hash); #endif int flags = 0; if (!NIL_P(option_hash)) rb_hash_foreach(option_hash, (int (*)(ANYARGS))cursor_put_flags, (VALUE)&flags); vkey = StringValue(vkey); vval = StringValue(vval); MDB_val key, value; key.mv_size = RSTRING_LEN(vkey); key.mv_data = RSTRING_PTR(vkey); value.mv_size = RSTRING_LEN(vval); value.mv_data = RSTRING_PTR(vval); check(mdb_cursor_put(cursor->cur, &key, &value, flags)); return Qnil; } |
#set(key, value = nil) ⇒ Array
1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1354 static VALUE cursor_set(int argc, VALUE* argv, VALUE self) { CURSOR(self, cursor); VALUE vkey, vval; MDB_val key, value; MDB_cursor_op op = MDB_SET_KEY; int ret; rb_scan_args(argc, argv, "11", &vkey, &vval); key.mv_size = RSTRING_LEN(vkey); key.mv_data = StringValuePtr(vkey); if (!NIL_P(vval)) { op = MDB_GET_BOTH; value.mv_size = RSTRING_LEN(vval); value.mv_data = StringValuePtr(vval); } ret = mdb_cursor_get(cursor->cur, &key, &value, op); if (!NIL_P(vval) && ret == MDB_NOTFOUND) return Qnil; check(ret); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |
#set_range(key) ⇒ Array
1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 |
# File 'ext/lmdb_ext/lmdb_ext.c', line 1389 static VALUE cursor_set_range(VALUE self, VALUE vkey) { CURSOR(self, cursor); MDB_val key, value; int ret; key.mv_size = RSTRING_LEN(vkey); key.mv_data = StringValuePtr(vkey); ret = mdb_cursor_get(cursor->cur, &key, &value, MDB_SET_RANGE); /* not sure why we were letting this throw an exception */ if (ret == MDB_NOTFOUND) return Qnil; check(ret); return rb_assoc_new(rb_str_new(key.mv_data, key.mv_size), rb_str_new(value.mv_data, value.mv_size)); } |