【Firefly API文档】—— Package DBentrust

http://bbs.gameres.com/thread_219653_1_1.html

package dbentrust

该包下面主要是数据库的处理与memcached存储。里面封装了,从memcached数据到python对象的映射。可以以操纵python对象的方式进行memcached中存储的数据的操作,只要在不同的进程中实例化相同名称的memobject对象,就能保证对象中的数据是一致的。还包含了将这个对象中的数据同步到数据库的出来方法。这里不需去写一句sql语句。

class DBPool
数据库连接池

InitPool
初始化数据库连接池
type method
//cwd firefly/dbentrust/dbpool.py
Prams initPool(**kw)

connection
获取一条数据库连接
type method
//cwd firefly/dbentrust/dbpool.py
Params connecton(self)

class Memclient
memcached 客户端连接类,通过加上前缀的方式类分配不同的命名空间。

connect
连接memcached服务
type method
//cwd firefly/dbentrust/memclient.py
Params connect(urls,hostname)

produceKey(keyname)
重新生成key
type method
//cwd firefly/dbentrust/memclient.py
Params produceKey(self,keyname)

get
获取key对应的值
type method
//cwd firefly/dbentrust/memclient.py
Prams get(key)

get_multi
一次获取多个key的值
@param keys: list(str) key的列表
type method
//cwd firefly/dbentrust/memclient.py
Params get_multi(key)

set
设置key对应的值
type method
//cwd firefly/dbentrust/memclient.py
Params set(keyname, value)

set_multi
修改多个key的值
type method
//cwd firefly/dbentrust/memclient.py
Params set_multi(mapping)

incr
自增
type method
//cwd firefly/dbentrust/memclient.py
Params incr(key, delta)

delete
删除指定key
type method
//cwd firefly/dbentrust/memclient.py
Params delete(key)

delete_multi
一次删除多个key
type method
//cwd firefly/dbentrust/memclient.py
Params delete_multi(keys)

flush_all
清空所有数据,慎用
type method
//cwd firefly/dbentrust/memclient.py
Params flush_all(self)

class MemObject
memcached 数据到python对象的映射类。通过继承这个类来实现memcached数据格式的自定义。

produceKey
重新生成key
type method
//cwd firefly/dbentrust/memobject.py
Params produceKey(self,keyname)

locked
检测对象是否被锁定
type method
//cwd firefly/dbentrust/memobject.py
Params lock(self)

lock
锁定对象
type method
//cwd firefly/dbentrust/memobject.py
Params lock(self)

release
释放锁
type method
//cwd firefly/dbentrust/memobject.py
Params release(self)

get
获取对象值
type method
//cwd firefly/dbentrust/memobject.py
Params get(key)

get_multi
一次获取多个key的值
type method
//cwd firefly/dbentrust/memobject.py
Params get_multi(keys)

update
修改对象的值
type method
//cwd firefly/dbentrust/memobject.py
Params update(key, values)

update_multi
同时修改多个对象的值
type method
//cwd firefly/dbentrust/memobject.py
Params update_multi(mapping)

mdelete
删除memcache中的数据
type method
//cwd firefly/dbentrust/memobject.py
Params mdelete(self)

incr
自增
type method
//cwd firefly/dbentrust/memobject.py
Params incr(key, delta)

insert
插入对象记录
type method
//cwd firefly/dbentrust/memobject.py
Params insert()

class Mmode
数据库到memcached直接的映射类。可以实现延迟异步的去修改数据库中的数据,减轻数据库压力。并有自定义的过期时间,过期后memcached中的数据会被自动的清理掉。这里对过期的定义的,这个对象被访问中间的间隔时间。这个类通过继承MemObject实现

update
修改某个字段的值
type method
//cwd firefly/dbentrust/mmode.py
Params update(name, pk, data={})

update_multi
修改多个字段的值
type method
//cwd firefly/dbentrust/ mmode.py
Params update_multi(mapping)

get
type method
//cwd firefly/dbentrust/ mmode.py
Params get(self, key)

get_multi
type method
//cwd firefly/dbentrust/ mmode.py
Params get_multi(self, keys)

delete
删除对象,这里只是修改状态为已经删除的状态
type method
//cwd firefly/dbentrust/ mmode.py
Params delete(self)

mdelete
清理对象,真正的清理掉memcached里的数据
type method
//cwd firefly/dbentrust/ mmode.py
Params mdelete(self)

IsEffective
检查对象是否有效
type method
//cwd firefly/dbentrust/ mmode.py
Params IsEffective(self)

syncDB
同步到数据库
type method
//cwd firefly/dbentrust/ mmode.py
Params syncDB(self)

checkSync
检测同步
type method
//cwd firefly/dbentrust/ mmode.py
Params checkSync(self,timeout=TIMEOUT)

class MFKMode
外键管理

class MAdmin
mmode管理器,可以根据主键获取一个mmode的实例。一个MAdmin管理器对应到的是数据库的某张表,继承与MemObject类。它的实例化方式如下
ma = MAdmin(“tb_user”,’id’,fk = ‘group’,incrkey=’id’)
user2 = ma.getObj(2)
user2.update(‘name’,‘test’)
表示对应的是数据库tb_user这张表,通过ma.getObj(2),可以获取id为2的这条记录的对应的mmode对象。user2.update(‘name’,‘test’)修改这条记录对应的name字段为‘test’。

insert
将信息写入memcached。
type method
//cwd firefly/dbentrust/ mmode.py
Params insert(self)

load
读取数据到数据库中,读取对应的表中的所有数据。
type method
//cwd firefly/dbentrust/ mmode.py
Params load(self)

madmininfo
获取Madmin的相关信息
type method
//cwd firefly/dbentrust/ mmode.py
Params madmininfo(self)

mfilter
查找符合的对象(效率低下,不推荐使用)
type method
//cwd firefly/dbentrust/ mmode.py
Params mfilter(self,kw)

getAllPkByFk
根据外键获取主键列表
type method
//cwd firefly/dbentrust/ mmode.py
Params getAllPkByFk(self,fk)

getObj
根据主键获取对应的记录的mmode对象。
type method
//cwd firefly/dbentrust/ mmode.py
Params getObj(pk)

getObjData
根据主键获取对应的记录的mmode对象的字段数据。
type method
//cwd firefly/dbentrust/ mmode.py
Params getObjData(self,pk)

getObjList
根据主键列表获取对应的记录的mmode对象的列表。
type method
//cwd firefly/dbentrust/ mmode.py
Params getObjList(self,pklist)

deleteMode
根据主键删除对应的mmode信息。
type method
//cwd firefly/dbentrust/ mmode.py
Params deleteMode(self,pk)

checkAll
检测同步管理的对象信息到数据库。并处理过期的对象
type method
//cwd firefly/dbentrust/ mmode.py
check()

deleteAllFk
删除所有的外键
type method
//cwd firefly/dbentrust/ mmode.py
Params deleteAllFk(self)

new
创建一个新的对象,对应的是在数据库中创建新的记录,但不是同步实时的。需要在checkAll执行后才能真正的同步到数据库中。
type method
//cwd firefly/dbentrust/ mmode.py
Params new(self,data)

class MadminManager
Madmin对象的管理器,实际上就是对整个库中的表的记录进行管理,但这个表对应的Madmin必须在这里被注册。

registe
注册Madmin管理器。
type method
//cwd firefly/dbentrust/ madminanager.py
Params registe(self,admin)

dropAdmin
取消对madmin对象的管理
type method
//cwd firefly/dbentrust/ madminanager.py
Params dropAdmin(self,adminname)

getAdmin
根据表名称获取注册过的madmin对象。

type method 
//cwd firefly/dbentrust/ madminanager.py
Params getAdmin(self,adminname)

checkAdmins
同步所有的注册的了madmin对应的记录到数据库中。
type method
//cwd firefly/dbentrust/ madminanager.py
Params checkAdmins(self)

 

【Firefly API文档】—— Package DBentrust

上一篇:MySQL中进程显式%的情况分析


下一篇:MySQL 关于毫秒和微秒的处理,MySQL获取毫秒!