Skip to content

Python (DB-API 2.0) Client for rqlite, the lightweight, distributed database built on SQLite.

License

Notifications You must be signed in to change notification settings

paulstuart/pydqlite

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pydqlite

This package contains a pure-Python dqlite client library.

  • Python -- one of the following:
  • dqlite Server

The last stable release is available on github and can be installed with pip:

$ cd
$ git clone https://github.com/paulstuart/pydqlite.git
$ pip install ./pydqlite

Alternatively (e.g. if pip is not available), a tarball can be downloaded from GitHub and installed with Setuptools:

$ # X.X is the desired pydqlite version (e.g. 0.5 or 0.6).
$ curl -L https://github.com/paulstuart/tarball/pydqlite-X.X | tar xz
$ cd pydqlite*
$ python setup.py install
$ # The folder pydqlite* can be safely removed now.

To run all the tests, execute the script setup.py:

$ python setup.py test

pytest (https://pytest.org/) and pytest-cov are required to run the test suite. They can both be installed with pip

The following code creates a connection and executes some statements:

import pydqlite.dbapi2 as dbapi2

# Connect to the database
connection = dbapi2.connect(
    host='localhost',
    port=4001,
)

try:
    with connection.cursor() as cursor:
        cursor.execute('CREATE TABLE foo (id integer not null primary key, name text)')
        cursor.executemany('INSERT INTO foo(name) VALUES(?)', seq_of_parameters=(('a',), ('b',)))

    with connection.cursor() as cursor:
        # Read a single record with qmark parameter style
        sql = "SELECT `id`, `name` FROM `foo` WHERE `name`=?"
        cursor.execute(sql, ('a',))
        result = cursor.fetchone()
        print(result)
        # Read a single record with named parameter style
        sql = "SELECT `id`, `name` FROM `foo` WHERE `name`=:name"
        cursor.execute(sql, {'name': 'b'})
        result = cursor.fetchone()
        print(result)
finally:
    connection.close()

This example will print:

OrderedDict([('id', 1), ('name', 'a')]) OrderedDict([('id', 2), ('name', 'b')])

Only qmark and named paramstyles (as defined in PEP 249) are supported.

Transactions are not supported.

DB-API 2.0: http://www.python.org/dev/peps/pep-0249

pydqlite is released under the MIT License. See LICENSE for more information.

About

Python (DB-API 2.0) Client for rqlite, the lightweight, distributed database built on SQLite.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 99.8%
  • Shell 0.2%