python 内存NoSQL数据库
python 内存NoSQL数据库
来自于网络,经过修改,秉承Open Source精神,回馈网络!
#!/usr/bin/python
#-*- coding: UTF-8 -*-
#
# memdb.py
# python memory db
#
# 2015-12
########################################################################
# The MIT License (MIT)
# http://opensource.org/licenses/MIT
#
# Copyright (c) 2015 copyright cheungmine
#
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
# "Software"), to deal in the Software without restriction, including
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so, subject
# to the following conditions:
#
# The above copyright notice and this permission notice shall be
# included in all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
########################################################################
from multiprocessing import RLock
# sync for threading
class ObjectSync:
def __init__(self, name):
self.refcount = 0
self.synclock = RLock()
self.keyname = name
def Lock(self):
self.synclock.acquire()
self.refcount = self.refcount + 1
def Unlock(self):
self.refcount = self.refcount - 1
self.synclock.release()
class ObjectSyncFactory:
def __init__(self):
self.globalLock = ObjectSync("")
self.rowlocks = {}
def __RemoveLock(self, sem, keyname):
self.globalLock.Lock()
self.rowlocks[keyname] = None
self.globalLock.Unlock()
def GetLock(self, tablename, key):
keyname = tablename + "," + str(key)
self.globalLock.Lock()
l = None
try:
l = self.rowlocks[keyname]
if l == None:
self.rowlocks[keyname] = ObjectSync(keyname)
l = self.rowlocks[keyname]
except:
self.rowlocks[keyname] = ObjectSync(keyname)
l = self.rowlocks[keyname]
self.globalLock.Unlock()
return l
class PairGuard:
def __init__(self, factory, sem):
self.syncfactory = factory
self.host = sem
self.host.Lock()
def __del__(self):
self.host.Unlock()
if self.host.refcount == 0 :
self.syncfactory._ObjectSyncFactory__RemoveLock(self.host, self.host.keyname)
########################################
# Database table
class MemTable:
def __init__(self):
self.rows = {}
self.tableLock = ObjectSync("")
def GetRowCount(self):
return len(self.rows)
def DeleteAll(self):
self.tableLock.Lock()
self.rows = {}
self.tableLock.Unlock()
def __DeleteAll(self):
self.rows = {}
def GetAllValue(self):
return self.rows
# throw KeyError if key not found.
def GetValue(self, key):
return self.rows[key]
# not exist: Add
# exist: Update
def AddValue(self, key, value):
self.tableLock.Lock()
self.rows[key] = value
self.tableLock.Unlock()
def __AddValue(self, key, value):
self.rows[key] = value
def DelValue(self, key):
self.AddValue(key,None)
def __DelValue(self, key):
self._MemTable__AddValue(key, None)
########################################
# MemDB
class MemDB:
def __init__(self):
self.tables = {}
self.syncFactory = ObjectSyncFactory()
# is not thread safed
def CreateTable(self, tablename):
self.tables[tablename] = MemTable()
# is not thread safed
def DropTable(self, tablename):
self.tables[tablename] = None
def GetValue(self, tablename, key):
mt = self.tables[tablename]
PairGuard(self.syncFactory, self.syncFactory.GetLock(tablename, key))
return mt.GetValue(key)
def AddValue(self, tablename, key, value):
mt = self.tables[tablename]
PairGuard(self.syncFactory, self.syncFactory.GetLock(tablename, key))
mt.AddValue(key, value)
def DelValue(self, tablename, key):
mt = self.tables[tablename]
PairGuard(self.syncFactory, self.syncFactory.GetLock(tablename, key))
mt.DelValue(key)
def __GetValue(self, tablename, key):
mt = self.tables[tablename]
return mt.GetValue(key)
def __AddValue(self, tablename, key, value):
mt = self.tables[tablename]
mt._MemTable__AddValue(key, value)
def __DelValue(self, tablename, key):
mt = self.tables[tablename]
mt._MemTable__DelValue(key)
class Transaction:
def __init__(self, conn):
self.dbconn = conn
self.logs = []
def Commit(self):
syncs = []
tables = {}
for p in self.logs:
tables[p[0]] = True
for name in tables:
syncTable = self.dbconn.memdb.syncFactory.GetLock(name, 'table')
syncs.append( (syncTable.keyname, syncTable) )
syncs.sort()
#lock
guards = []
for sync in syncs:
guards.append(PairGuard(self.dbconn.memdb.syncFactory, sync[1]))
#commit
self.logs.reverse()
while True:
if len(self.logs) == 0:
break
p = self.logs.pop()
self.dbconn.memdb._MemDB__AddValue(p[0], p[1], p[2])
#unlock
guards.reverse()
while True:
if len(guards) == 0:
break
guards.pop()
self.dbconn._MemDBConnect__EndTransaction()
def Rollback(self):
self.dbconn._MemDBConnect__EndTransaction()
def LogPoint(self, tablename, key, value):
self.logs.append((tablename, key, value))
class MemDBConnect:
def __init__(self, db):
self.memdb = db
self.bTransaction = False
self.trans = None
def BeginTransaction(self):
self.bTransaction = True
self.trans = Transaction(self)
return self.trans
def __EndTransaction(self):
self.bTransaction = False
self.trans = None
def CommitTransaction(self):
if self.bTransaction:
self.bTransaction = False
ts = self.trans
self.trans = None
if ts:
ts.Commit()
def RollbackTransaction(self):
if self.bTransaction:
self.bTransaction = False
ts = self.trans
self.trans = None
if ts:
ts.Rollback()
# not thread safe
def CreateTable(self, tablename):
self.memdb.CreateTable(tablename)
# not thread safe
def DropTable(self, tablename):
self.memdb.DropTable(tablename)
# not thread safe
def HasTable(self, tablename):
if self.memdb.tables.get(tablename):
return True
else:
return False
def GetValue(self, tablename, key):
if self.bTransaction:
return self.memdb._MemDB__GetValue(tablename, key)
else:
return self.memdb.GetValue(tablename, key)
def AddValue(self, tablename, key, value):
if self.bTransaction:
self.trans.LogPoint(tablename, key, value)
else:
self.memdb.AddValue(tablename, key, value)
def DelValue(self, tablename, key):
if self.bTransaction:
self.trans.LogPoint(tablename, key, None)
else:
self.memdb.DelValue(tablename, key)
def QueryTablesNothrow(self):
tables = []
try:
self.BeginTransaction()
for tablename,_ in self.memdb.tables.items():
tables.append(tablename)
self.CommitTransaction()
except:
tables = []
self.RollbackTransaction()
finally:
return tables
def QueryTableKeysNothrow(self, tablename):
keys = []
try:
self.BeginTransaction()
if self.HasTable(tablename):
rows_dict = self.memdb.tables[tablename].rows
for key, _ in rows_dict.items():
keys.append(key)
self.CommitTransaction()
except:
keys = []
self.RollbackTransaction()
finally:
return keys
def CreateTableNothrow(self, tablename):
try:
self.BeginTransaction()
if not self.HasTable(tablename):
self.memdb.CreateTable(tablename)
self.CommitTransaction()
except:
self.RollbackTransaction()
finally:
pass
def DropTableNothrow(self, tablename):
try:
self.BeginTransaction()
if self.HasTable(tablename):
self.memdb.DropTable(tablename)
self.CommitTransaction()
except:
self.RollbackTransaction()
finally:
pass
def GetValueNothrow(self, tablename, key, defaultvalue):
result = defaultvalue
try:
self.BeginTransaction()
result = self.GetValue(tablename, key)
self.CommitTransaction()
except:
self.RollbackTransaction()
finally:
return result
def AddValueNothrow(self, tablename, key, value):
result = False
try:
self.BeginTransaction()
self.AddValue(tablename, key, value)
self.CommitTransaction()
result = True
except:
self.RollbackTransaction()
finally:
return result
def DelValueNothrow(self, tablename, key):
result = False
try:
self.BeginTransaction()
self.DelValue(tablename, key)
self.CommitTransaction()
result = True
except:
self.RollbackTransaction()
finally:
return result
def AppendValueListNothrow(self, tablename, key, value, non_repeated_value):
try:
self.BeginTransaction()
if self.HasTable(tablename):
try:
values = self.GetValue(tablename, key)
if non_repeated_value:
if value not in values:
values.append(value)
self.AddValue(tablename, key, values)
else:
values.append(value)
self.AddValue(tablename, key, values)
except KeyError:
self.AddValue(tablename, key, [value])
finally:
self.CommitTransaction()
except:
self.RollbackTransaction()
finally:
pass
def AppendValueListMultiNothrow(self, tablenames, keys, values, non_repeated_values):
try:
self.BeginTransaction()
for i in range(0, len(tablenames)):
t, k, v, nrv = tablenames[i], keys[i], values[i], non_repeated_values[i]
if self.HasTable(t):
try:
vals = self.GetValue(t, k)
if nrv:
if v not in vals:
vals.append(v)
self.AddValue(t, k, vals)
else:
vals.append(v)
self.AddValue(t, k, vals)
except KeyError:
self.AddValue(t, k, [v])
self.CommitTransaction()
except:
self.RollbackTransaction()
finally:
pass
用法1:
可以直接嵌入到python中:
def test():
db = MemDB()
tname = "table1"
db.CreateTable(tname)
#for i in range(100000):
# db.AddValue(tname,i,"sdfsd")
db.AddValue(tname,11,"sdfsd")
print db.GetValue(tname, 11)
db.AddValue(tname,11,"dddddd")
print db.GetValue(tname,11)
db.AddValue(tname,12,"dsfdsfd")
print db.GetValue(tname,12)
conn = MemDBConnect(db)
t = conn.BeginTransaction()
for i in range(100000):
conn.AddValue(tname,i,"sdfsd")
conn.AddValue(tname,12,"sfdas")
conn.AddValue(tname,12,"ddddd")
t.Commit()
print db.GetValue(tname,12)
python 内存NoSQL数据库的更多相关文章
- Python操作nosql数据库之redis
一.NoSQL的操作 NoSQL,泛指非关系型的数据库.随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不 ...
- python操作nosql数据库之memcache
一.memcache的安装 1.memcache简介 Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象减少读取数据库的次数,从而 ...
- 性能超越 Redis 的 NoSQL 数据库 SSDB
idea's blog - 性能超越 Redis 的 NoSQL 数据库 SSDB 性能超越 Redis 的 NoSQL 数据库 SSDB C/C++语言编程, SSDB Views: 8091 | ...
- 孤荷凌寒自学python第五十天第一次接触NoSql数据库_Firebase
孤荷凌寒自学python第五十天第一次接触NoSql数据库_Firebase (完整学习过程屏幕记录视频地址在文末) 之前对关系型数据库的学习告一段落,虽然能力所限没有能够完全完成理想中的所有数据库操 ...
- 用 Python 写一个 NoSQL 数据库Python
NoSQL 这个词在近些年正变得随处可见. 但是到底 “NoSQL” 指的是什么? 它是如何并且为什么这么有用? 在本文, 我们将会通过纯 Python (我比较喜欢叫它, “轻结构化的伪代码”) 写 ...
- NoSQL数据库笔谈(转)
NoSQL数据库笔谈 databases , appdir , node , paper颜开 , v0.2 , 2010.2 序 思想篇 CAP 最终一致性 变体 BASE 其他 I/O的五分钟法则 ...
- 15个nosql数据库
1.MongoDB 介绍 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.主要解决的是海量数据的访问效率问题,为WEB应用提供可扩展的高性能数据存储解决方案.当数据量达到50GB以上 ...
- NoSQL 数据库产品学习总结(一)
NoSQL 数据库产品学习总结(一) 本篇文章共分为四个章节,会陆续整理下 Memcached.Redis.tair.mongodb.hbase.SequoiaDB. Cassandra的相关知识. ...
- NoSQL 数据库的使用场景
摘要:对比传统关系型数据库,NoSQL有着更为复杂的分类——键值.面向文档.列存储.图数据库.这里就带你一览NoSQL各种类型的适用场景及一些知名公司的方案选择. 在过去几年,关系型数据库一直是数据持 ...
随机推荐
- C语言 递归 汉诺塔问题 最大公约数问题
函数不能嵌套定义,但能嵌套调用(在调用一个函数的过程中再调用另一个函数) 函数间接或直接调用自己,称为递归调用 汉诺塔问题 思想:简化为较为简单的问题 n=2 较为复杂的问题,采用数学归纳方法分析 ...
- 总结angular+ionic项目中的问题
1:tab的路由导向问题 运用ion-tabs时,第一个ion-tabs标签下的href功能会覆盖掉路由中定义的默认路由(进入应用后直接加载href指向的组件). 解决方法:多写一个ion-tabs标 ...
- 643. Maximum Average Subarray
Given an array consisting of \(n\) integers, find the contiguous subarray of given length \(k\) that ...
- Oracle中case用法总结
--case语句的种类: .简单case语句 语法: case exp when comexp then returnvalue ... when comexp then returnvalue el ...
- PHP 完整表单实例
PHP - 在表单中确保输入值 在用户点击提交按钮后,为确保字段值是否输入正确,我们在HTML的input元素中插添加PHP脚本, 各字段名为: name, email, 和 website. 在评论 ...
- iOS开源照片浏览器框架SGPhotoBrowser的设计与实现
简介 近日在制作一个开源加密相册时附带着设计了一个照片浏览器,在进一步优化后发布到了GitHub供大家使用,该框架虽然没有MWPhotoBrowser那么强大,但是使用起来更为方便,操作更符合常规相册 ...
- iOS开源加密相册Agony的实现(一)
简介 虽然目前市面上有一些不错的加密相册App,但不是内置广告,就是对上传的张数有所限制.本文介绍了一个加密相册的制作过程,该加密相册将包括多密码(输入不同的密码即可访问不同的空间,可掩人耳目).Wi ...
- Android简易实战教程--第四十五话《几种对话框》
Android中提供了各种原生的对话框,在使用简单的功能的时候,还不比考虑自定义,使用原生的也能完成功能.本篇简单小案例就介绍三种对话框. 还是直接上代码吧: 布局中三个点击事件的按钮: <Li ...
- ubuntu挂载的NTFS文件编译失败问题
错误: 编译Android源代码时候出现,权限拒绝的错误 解决方法: sudo apt-get install ntfs-config sudo ntfs-config 我的微信二维码如下,欢迎交流讨 ...
- 1.cocos2dx 3.2环境搭建
1 所需软件 jdk-7u25-windows-i586.exe python-2.7.8.amd64.msi cocos2d-x-3.2.zip apache-ant-1.9.4.zi ...