python sqlite多線程編程

來源:互聯網
上載者:User
.前言為什麼要特別指出sqlite的多線程呢?因為建立一個sqlite串連只能給建立這個串連的線程使用,按照串連池的一般做法,先初始化幾條串連conn放到池裡,顯然不行(別的線程用不了)。如果換一種策略,在第一次使用串連時,才由線程建立串連,然後映射到線程推到池裡,在串連使用前先驗證串連是否可用--這是一種不錯的實現。
下面,是簡單實現,不涉及池~~,有時間在實現。
  1. 首先,定義一個類,操作某資料庫test表的增.刪.查,命名為testDao,哦,no!這名命名太狗血了吧。
    import threadingimport os,sqlite3class Dao(object):    '''    資料持久化處理類    '''        def __init__(self,path,name='',*args,**kwargs):        '''        初始化工作...        '''        self.lock = threading.RLock() #鎖        self.name = name        self.path = path #資料庫連接參數        db_path = self.path[:self.path.rfind(os.sep)]        if os.path.exists(db_path):            os.makedirs(db_path)             def get_conn(self):        '''        建立串連,為什麼不能設定為執行個體成員?自己想想,--        '''        conn = sqlite3.connect(self.path)        return conn        def conn_close(self,conn=None):        '''        操作完,關掉串連        '''        conn.close()            def save(self,obj,conn=None):        '''        儲存資料        '''        cu = conn.cursor()        cu.execute(obj.to_insert_sql())        

  2. 定義資料庫連接相關的攔截器.在func調用前串連資料庫,func調用結束提高事務並關閉串連.
    def conn_trans(func):    '''    資料庫連接相關的攔截器.在func調用前串連資料庫,func調用結束提高事務並關閉串連.    '''    def connection(self,*args,**kwargs):        self.lock.acquire()        conn = self.get_conn()        kwargs['conn'] = conn        rs = func(self,*args,**kwargs)        self.conn_close(conn)        self.lock.release()        return rs    return connection

  3. 使用攔截器,攔截save方法
    @conn_trans()      def save(self,obj,conn=None):        '''        儲存資料        '''        cu = conn.cursor()        cu.execute(obj.to_insert_sql())        


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.