Releases: tidesdb/tidesdb-python
Releases · tidesdb/tidesdb-python
v0.4.0
Official release of TidesDB Python binding v0.4.0.
Install
Installing latest version from source using pip.
pip install git+https://github.com/tidesdb/tidesdb-python.git
Usage
Getting current TidesDB module version
import tidesdb
print(tidesdb.__version__)
Basic operations
from tidesdb import TidesDB, TidesDBCompressionAlgo, TidesDBMemtableDS
# Open a TidesDB database
db = TidesDB.open('my_db')
# Create a column family
db.create_column_family(
"my_column_family",
1024*1024*64, # Flush threshold (64MB)
12, # Max level skip list, if using hash table is irrelevant
0.24, # Probability skip list, if using hash table is irrelevant
True, # Enable compression, is slower
TidesDBCompressionAlgo.COMPRESS_SNAPPY, # Compression algorithm can be NO_COMPRESSION, COMPRESS_SNAPPY, COMPRESS_LZ4, COMPRESS_ZSTD
True, # Enable bloom filter
TidesDBMemtableDS.SKIP_LIST # Use skip list for memtable
)
# Put key-value pair into the database
db.put("my_column_family", b"key1", b"value1", ttl=3600) # ttl=-1 for no ttl
# Get the value for the key
value = db.get("my_column_family", b"key1")
print(f"Key: key1, Value: {value}")
# Delete the key-value pair
db.delete("my_column_family", b"key1")
# Try to get the deleted key (should raise an exception or return None)
try:
value = db.get("my_column_family", b"key1")
except Exception as e:
print(f"Error: {e}")
# Close the database
db.close()
Using Transactions
from tidesdb import TidesDB, Transaction, TidesDBCompressionAlgo, TidesDBMemtableDS
# Open the database
db = TidesDB.open('my_db')
# Create a column family
db.create_column_family(
"my_column_family",
1024*1024*64, # Flush threshold (64MB)
12, # Max level skip list, if using hash table is irrelevant
0.24, # Probability skip list, if using hash table is irrelevant
True, # Enable compression
TidesDBCompressionAlgo.COMPRESS_SNAPPY, # Compression algorithm can be NO_COMPRESSION, COMPRESS_SNAPPY, COMPRESS_LZ4, COMPRESS_ZSTD
True, # Enable bloom filter
TidesDBMemtableDS.SKIP_LIST # Use skip list for memtable
)
# Begin a transaction on the column family
txn = Transaction.begin(db, "my_column_family")
# Put multiple key-value pairs in the transaction
txn.put(b"key2", b"value2", ttl=-1)
txn.put(b"key3", b"value3", ttl=-1)
# Commit the transaction
txn.commit()
# Verify the values
value2 = db.get("my_column_family", b"key2")
value3 = db.get("my_column_family", b"key3")
print(f"Key: key2, Value: {value2}")
print(f"Key: key3, Value: {value3}")
# Close the database
db.close()
Using Cursor
from tidesdb import TidesDB, Cursor, TidesDBCompressionAlgo, TidesDBMemtableDS
# Open the database
db = TidesDB.open('my_db')
# Create a column family
db.create_column_family(
"my_column_family",
1024*1024*64, # Flush threshold (64MB)
12, # Max level skip list, if using hash table is irrelevant
0.24, # Probability skip list, if using hash table is irrelevan
True, # Enable compression
TidesDBCompressionAlgo.COMPRESS_SNAPPY, # Compression algorithm can be NO_COMPRESSION, COMPRESS_SNAPPY, COMPRESS_LZ4, COMPRESS_ZSTD
True, # Enable bloom filter
TidesDBMemtableDS.SKIP_LIST # Use skip list for memtable or HASH_TABLE
)
# Insert some key-value pairs
db.put("my_column_family", b"key1", b"value1", ttl=3600)
db.put("my_column_family", b"key2", b"value2", ttl=3600)
db.put("my_column_family", b"key3", b"value3", ttl=3600)
# Initialize the cursor to iterate over the column family
cursor = Cursor.init(db, "my_column_family")
# Loop to fetch and print all key-value pairs
try:
while True:
key, value = cursor.get()
print(f"Key: {key}, Value: {value}")
cursor.next() # Move to the next element
except Exception as e:
# Exception is raised when there are no more elements to iterate
print("End of column family reached.")
try:
while True:
key, value = cursor.get()
print(f"Key: {key}, Value: {value}")
cursor.prev() # Move to the previous element
except Exception as e:
# Exception is raised when there are no more elements to iterate
print("Start of column family reached.")
# Free the cursor resources
cursor.free()
# Close the database
db.close()
Listing Column Families
from tidesdb import TidesDB
# Open the database
db = TidesDB.open('my_db')
# List all column families in the database
column_families = db.list_column_families()
print(f"Column families: \n{column_families}")
# Close the database
db.close()
Dropping Column Family
from tidesdb import TidesDB
# Open the database
db = TidesDB.open('my_db')
# Drop the specified column family
db.drop_column_family("my_column_family")
# Close the database
db.close()
Compacting Column Family SSTables
Compaction will cut the amount of SSTables for a column family in half by pairing, merging and removing expired and tombstoned keys for the specified column family, with a specified number of threads.
db.compact_sstables("my_column_family", max_threads=4) # max threads is refering to amount of threads used for compaction process
# 4 threads means 2 sstables being paired per thread which is faster than a lone thread say.
What's Changed
- Rough python library start of implementation. by @guycipher in #1
- minor comments and read me update by @guycipher in #2
- remove possibly unwarranted classifier in setup.py by @guycipher in #3
- feat(tests): Add comprehensive test suite for TidesDB. by @imprvhub in #6
- Updated python package with finalized create column family changes. … by @guycipher in #7
- read me update by @guycipher in #8
- Made library configuration automated so essentially the idea is tides… by @guycipher in #10
- read me correction for ttl by @guycipher in #11
- to correct issue #12 missing tidesdb module. We are missing an __ini… by @guycipher in #13
- Read me additions by @guycipher in #14
New Contributors
- @guycipher made their first contribution in #1
- @imprvhub made their first contribution in #6
Full Changelog: https://github.com/tidesdb/tidesdb-python/commits/v0.4.0