Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/astynax/py-toy-db
Pure-Python "toy" DataBase
https://github.com/astynax/py-toy-db
Last synced: 19 days ago
JSON representation
Pure-Python "toy" DataBase
- Host: GitHub
- URL: https://github.com/astynax/py-toy-db
- Owner: astynax
- License: mit
- Created: 2013-09-24T16:06:00.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2013-10-28T12:10:12.000Z (about 11 years ago)
- Last Synced: 2023-08-03T03:55:29.011Z (over 1 year ago)
- Language: Python
- Size: 551 KB
- Stars: 0
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Py-Toy-DB - Python Toy DataBase
Pure-Python "игрушечная" *документо-ориентированная СУБД*.
[Подробнее в Wiki](https://github.com/astynax/py-toy-db/wiki)
## Примеры использования
### Работа с Depository
>>> from pytoydb.depository import Depository
>>> from pytoydb.config import configureПример наших данных которые мы собираемся хранить.
Их может быть много и разных:>>> class MyDataCls(object):
... a=1Данные
>>> my_data = {'my_awesome_record':{'first_field':1, 'last_field':'1'}}
создадим хранилище
>>> dep = Depository(configure())
добавление
>>> dict_id = dep.add(my_data)
Получение
>>> dep.get(dict_id)
{'my_awesome_record': {'first_field': 1, 'last_field': '1'}}удаление
>>> dep.remove(dict_id)
>>> dep.get(dict_id)
Traceback (most recent call last):
...
IndexError: Запись с идентификатором 1 не найдена### Работа с IndexedDepository
Импорты:
>>> from pytoydb.depository import IndexedDepository
>>> from pytoydb.index import HashIndex
>>> from pytoydb.config import configure
>>> from pprint import pprintСоздаем хранилище:
>>> dep = IndexedDepository(
... configure(
... indexes=(
... ('a', HashIndex, (lambda x: x.get('a'),)),
... ('b', HashIndex, (lambda x: x.get('b'),))
... )
... ))Добавляем записи (возвращаются *id* записей):
>>> dep.add({'a': 1, 'b': 101})
1
>>> dep.add({'a': 2, 'b': 102, 'c': 456, 2: 4})
2
>>> dep.add({'a': 1, 'b': 103})
3
>>> dep.add({'a': 3})
4
>>> dep.add({'a': 2, 'b': 101, 101: 'b'})
5Теперь можно делать выборки по запросам:
>>> show = lambda x: pprint(list(x))
>>> show( dep.query )
[(1, {'a': 1, 'b': 101}),
(2, {2: 4, 'a': 2, 'b': 102, 'c': 456}),
(3, {'a': 1, 'b': 103}),
(4, {'a': 3}),
(5, {101: 'b', 'a': 2, 'b': 101})]>>> show( dep.query('a', 1) )
[(1, {'a': 1, 'b': 101}), (3, {'a': 1, 'b': 103})]>>> show( dep.query('a', 2) )
[(2, {2: 4, 'a': 2, 'b': 102, 'c': 456}), (5, {101: 'b', 'a': 2, 'b': 101})]>>> show( dep.query('b', 101) )
[(1, {'a': 1, 'b': 101}), (5, {101: 'b', 'a': 2, 'b': 101})]Запросы можно сохранять, но нужно помнить, что они *ленивые*, и выполняются только при итерации по объекту запроса:
>>> q = dep.query('a', 2)('b', 101)
>>> show(q)
[(5, {101: 'b', 'a': 2, 'b': 101})]
>>> dep.remove(5)
>>> show(q)
[]### Работа с ThreadsafeDepository
>>> from pytoydb.depository import ThreadsafeDepository
>>> from pytoydb.config import configureСоздаем экземпляр хранилища и запускаем его. По-умолчанию будем работать в памяти.
>>> dep = ThreadsafeDepository(configure())
>>> dep.start()Определим клиента (поток), который будет работать с хранилицем.
>>> import threading
>>> class Client(threading.Thread):
... def __init__(self, depository):
... threading.Thread.__init__(self)
... self.dep = depository
... def run(self):
... while True:
... print self.dep.add({'test':'test'}, wait=True)
... print self.dep.add({'test':'test'})Запуск нескольких экземпляров
>>> for i in range(5):
... Client(dep).start()