當前位置: 首頁>>代碼示例>>Python>>正文


Python sqlitecachedb.SQLiteCacheDB類代碼示例

本文整理匯總了Python中BaseLib.Core.CacheDB.sqlitecachedb.SQLiteCacheDB的典型用法代碼示例。如果您正苦於以下問題:Python SQLiteCacheDB類的具體用法?Python SQLiteCacheDB怎麽用?Python SQLiteCacheDB使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了SQLiteCacheDB類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: setUp

 def setUp(self):
     db_path = TRIBLER_DB_PATH
     db = SQLiteCacheDB.getInstance()
     db.initDB(db_path, busytimeout=BUSYTIMEOUT)
     launchmany = FakeLaunchmany(db)
     overlay_bridge = FakeOverlayBridge()
     self.datahandler = DataHandler(launchmany, overlay_bridge)
開發者ID:vbit,項目名稱:IJS-stuff,代碼行數:7,代碼來源:test_buddycast.py

示例2: test_open_close_db

 def test_open_close_db(self):
     sqlite_test = SQLiteCacheDB.getInstance()
     sqlite_test.openDB(self.db_path, 1250)
     sqlite_test.close()
     sqlite_test.close()
     sqlite_test.openDB(self.db_path, 0)
     sqlite_test.close()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:7,代碼來源:test_sqlitecachedb.py

示例3: read_data

    def read_data(self):
        db = SQLiteCacheDB.getInstance()
        one = db.fetchone('select * from person')
        assert one == ('a','b'), str(one)
        
        one = db.fetchone("select lastname from person where firstname == 'b'")
        assert one == 'a'

        one = db.fetchone("select lastname from person where firstname == 'c'")
        assert one == None
        
        all = db.fetchall('select * from person')
        assert len(all) == 101, len(all)
        
        num = db.size('person')
        assert num == 101
        
        db.insert('person', lastname='1', firstname='abc')
        one = db.fetchone("select firstname from person where lastname == '1'")
        assert one == '1' or one == 'abc'
        all = db.fetchall("select firstname from person where lastname == '1'")
        assert len(all) == 2
        
        db.update('person', "lastname == '2'", firstname='56')
        one = db.fetchone("select firstname from person where lastname == '2'")
        assert one == '56', one
        
        db.update('person', "lastname == '3'", firstname=65)
        one = db.fetchone("select firstname from person where lastname == '3'")
        assert one == 65, one
        
        db.update('person', "lastname == '4'", firstname=654, lastname=44)
        one = db.fetchone("select firstname from person where lastname == 44")
        assert one == 654, one
        db.close()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:35,代碼來源:test_sqlitecachedb.py

示例4: keep_reading_data

 def keep_reading_data(self, period):
     db = SQLiteCacheDB.getInstance()
     st = time()
     oldnum = 0
     self.all = []
     self.read_times = 0
     if DEBUG_R:
         print "begin read", self.getName(), period, time()
     while True:
         et = time()
         if et-st > period:
             break
         if DEBUG_R:
             print "...start read", self.getName(), time()
             sys.stdout.flush()
         
         try:
             self.all = db.fetchall("select * from person")
             self.last_read = time()-st
             self.read_times += 1
         except Exception, msg:
             print_exc()
             print "*-*", Exception, msg
             self.read_locks += 1
             if DEBUG:
                 print >> sys.stdout, "Locked while reading!", self.read_locks
                 sys.stdout.flush()
         else:
             if DEBUG_R:
                 print "...end read", self.getName(), time(), len(self.all)
                 sys.stdout.flush()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:31,代碼來源:test_sqlitecachedb.py

示例5: keep_writing_data

            def keep_writing_data(self, period, num_write, commit=False):
                db = SQLiteCacheDB.getInstance()
                st = time()
                if DEBUG:
                    print "begin write", self.getName(), period, time()
                    sys.stdout.flush()
                begin_time = time()
                w_times = []
                c_times = []
                self.last_write = 0
                try:
                    while True:
                        st = time()
                        if st-begin_time > period:
                            break
                        #db.begin()
                        values = []
                        
                        for i in range(num_write):
                            value = (str(i)+'"'+"'", str(i**2)+'"'+"'")
                            values.append(value)
                        
                        try:
                            st = time()
                            if DEBUG:
                                print '-'+self.num + "start write", self.getName(), self.writes, time()-begin_time
                                sys.stdout.flush()
                                
                            sql = 'INSERT INTO person VALUES (?, ?)'
                            db.executemany(sql, values, commit=commit)
                            self.last_write = time()-begin_time

                            write_time = time()-st
                            w_times.append(write_time)
                            if DEBUG:
                                print '-'+self.num + "end write", self.getName(), '+', write_time 
                                sys.stdout.flush()
                            self.writes += 1
                        except apsw.BusyError:
                            self.write_locks += 1
                            if DEBUG:
                                if commit:
                                    s = "Writing/Commiting"
                                else:
                                    s = "Writing"
                                print >> sys.stdout, '>'+self.num + "Locked while ", s, self.getName(), self.write_locks, time()-st
                                sys.stdout.flush()
                            continue
                                                
                        if SLEEP_W >= 0:
                            sleep(SLEEP_W/1000.0)
                            
                        if DO_STH > 0:
                            do_sth(DO_STH)
                            
                except Exception, msg:
                    print_exc()
                    print >> sys.stderr, "On Error", time(), begin_time, time()-begin_time, Exception, msg, self.getName()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:58,代碼來源:test_sqlitecachedb.py

示例6: create_db

 def create_db(self, db_path, busytimeout=DEFAULT_BUSY_TIMEOUT):
     create_sql = "create table person(lastname, firstname);"
     db = SQLiteCacheDB.getInstance()
     tmp_sql_path = 'tmp.sql'
     f = open(tmp_sql_path, 'w')
     f.write(create_sql)
     f.close()
     #print "initDB", db_path
     db.initDB(db_path, tmp_sql_path, busytimeout=busytimeout, check_version=False)
     os.remove(tmp_sql_path)
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:10,代碼來源:test_sqlitecachedb.py

示例7: __init__

    def __init__(self):
        self._sqlite_cache_db = SQLiteCacheDB.getInstance()

        crawler = Crawler.get_instance()
        if crawler.am_crawler():
            self._file = open("databasecrawler.txt", "a")
            self._file.write("".join(("# ", "*" * 80, "\n# ", strftime("%Y/%m/%d %H:%M:%S"), " Crawler started\n")))
            self._file.flush()
        else:
            self._file = None
開發者ID:Anaconda84,項目名稱:Anaconda,代碼行數:10,代碼來源:DatabaseCrawler.py

示例8: setUp

 def setUp(self):
     self.db = SQLiteCacheDB.getInstance()
     self.db.initDB(TRIBLER_DB_PATH_BACKUP)
     
     permid = {}
     permid[3127] = 'MFIwEAYHKoZIzj0CAQYFK4EEABoDPgAEAcPezgQ13k1MSOaUrCPisWRhYuNT7Tm+q5rUgHFvAWd9b+BcSut6TCniEgHYHDnQ6TH/vxQBqtY8Loag'
     permid[994] = 'MFIwEAYHKoZIzj0CAQYFK4EEABoDPgAEAJUNmwvDaigRaM4cj7cE2O7lessqnnFEQsan7df9AZS8xeNmVsP/XXVrEt4t7e2TNicYmjn34st/sx2P'
     permid[19] = 'MFIwEAYHKoZIzj0CAQYFK4EEABoDPgAEAAJv2YLuIWa4QEdOEs4CPRxQZDwZphKd/xK/tgbcALG198nNdT10znJ2sZYl+OJIvj7YfYp75PrrnWNX'
     permid[5] = 'MFIwEAYHKoZIzj0CAQYFK4EEABoDPgAEAAB0XbUrw5b8CrTrMZST1SPyrzjgSzIE6ynALtlZASGAb+figVXRRGpKW6MSal3KnEm1/q0P3JPWrhCE'
     self.permid = permid
     
     db = MyPreferenceDBHandler.getInstance()
     db.loadData()
開發者ID:gvsurenderreddy,項目名稱:smoothit-client,代碼行數:13,代碼來源:test_torrentcollecting.py

示例9: write_data

 def write_data(self):
     db = SQLiteCacheDB.getInstance()
     #db.begin()
     db.insert('person', lastname='a', firstname='b')
     values = []
     for i in range(100):
         value = (str(i), str(i**2))
         values.append(value)
     db.insertMany('person', values)
     db.commit()
     #db.begin()
     db.commit()
     db.commit()
     db.close()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:14,代碼來源:test_sqlitecachedb.py

示例10: setUp

    def setUp(self):
        self.file_path = tempfile.mktemp()
        self.db_path = tempfile.mktemp()
        
        #print >>sys.stderr,"test: file_path",self.file_path
        #print >>sys.stderr,"test: db_path",self.db_path
        
        self.writeSuperPeers()
        head,tail = os.path.split(self.file_path)
        self.config = {'install_dir':head, 'superpeer_file':tail}

        self.db = SQLiteCacheDB.getInstance()
        self.db.initDB(self.db_path, CREATE_SQL_FILE, check_version=False)
        self.splist = SuperPeerDBHandler.getInstance()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:14,代碼來源:test_superpeers.py

示例11: basic_funcs

    def basic_funcs(self):
        db = SQLiteCacheDB.getInstance()
        create_sql = "create table person(lastname, firstname);"
        db.createDBTable(create_sql, self.db_path)
        db.insert('person', lastname='a', firstname='b')
        one = db.fetchone('select * from person')
        assert one == ('a','b')
        
        one = db.fetchone("select lastname from person where firstname == 'b'")
        assert one == 'a'

        one = db.fetchone("select lastname from person where firstname == 'c'")
        assert one == None

        values = []
        for i in range(100):
            value = (str(i), str(i**2))
            values.append(value)
        db.insertMany('person', values)
        all = db.fetchall('select * from person')
        assert len(all) == 101
        
        all = db.fetchall("select * from person where lastname=='101'")
        assert all == []
        
        num = db.size('person')
        assert num == 101
        
        db.insert('person', lastname='1', firstname='abc')
        one = db.fetchone("select firstname from person where lastname == '1'")
        assert one == '1' or one == 'abc'
        all = db.fetchall("select firstname from person where lastname == '1'")
        assert len(all) == 2
        
        db.update('person', "lastname == '2'", firstname='56')
        one = db.fetchone("select firstname from person where lastname == '2'")
        assert one == '56', one
        
        db.update('person', "lastname == '3'", firstname=65)
        one = db.fetchone("select firstname from person where lastname == '3'")
        assert one == 65, one
        
        db.update('person', "lastname == '4'", firstname=654, lastname=44)
        one = db.fetchone("select firstname from person where lastname == 44")
        assert one == 654, one
        
        db.close()
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:47,代碼來源:test_sqlitecachedb.py

示例12: test_insertPeer

 def test_insertPeer(self):
     create_sql = """
     CREATE TABLE Peer (
       peer_id              integer PRIMARY KEY AUTOINCREMENT NOT NULL,
       permid               text NOT NULL,
       name                 text,
       ip                   text,
       port                 integer,
       thumbnail            text,
       oversion             integer,
       similarity           numeric,
       friend               integer,
       superpeer            integer,
       last_seen            numeric,
       last_connected       numeric,
       last_buddycast       numeric,
       connected_times      integer,
       buddycast_times      integer,
       num_peers            integer,
       num_torrents         integer,
       num_prefs            integer,
       num_queries          integer
     );
     """
     db = SQLiteCacheDB.getInstance()
     db.createDBTable(create_sql, self.db_path)
     assert db.size('Peer') == 0
     fake_permid_x = 'fake_permid_x'+'0R0\x10\x06\x07*\x86H\xce=\x02\x01\x06\x05+\x81\x04\x00\x1a\x03>\x00\x04'
     peer_x = {'permid':fake_permid_x, 'ip':'1.2.3.4', 'port':234, 'name':'fake peer x'}
     permid = peer_x.pop('permid')
     db.insertPeer(permid, update=False, **peer_x)
     assert db.size('Peer') == 1
     assert db.getOne('Peer', 'name', peer_id=1) == peer_x['name']
     peer_x['port']=456
     db.insertPeer(permid, update=False, **peer_x)
     assert db.getOne('Peer', 'port', peer_id=1) == 234
     db.insertPeer(permid, update=True, **peer_x)
     assert db.getOne('Peer', 'port', peer_id=1) == 456
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:38,代碼來源:test_sqlitecachedb.py

示例13: __init__

 def __init__(self, db=SQLiteCacheDB.getInstance()):
     # notice that singleton pattern is not enforced.
     # This way the code is more easy
     # to test.
     
     try:
         MetadataDBHandler._lock.acquire()
         MetadataDBHandler.__single = self
     finally:
         MetadataDBHandler._lock.release()
     
     try:
         self._db = db
         # Don't know what those life should know. Assuming I don't need 
         # them 'till a countrary proof! (Ask Nitin) 
         # BasicDBHandler.__init__(self,db,METADATA_TABLE)
         # BasicDBHandler.__init__(self,db,SUBTITLES_TABLE)
         print >> sys.stderr, time.asctime(),'-', "Metadata: DB made" 
     except: 
         print >> sys.stderr, time.asctime(),'-', "Metadata: couldn't make the tables"
     
     
     print >> sys.stderr, time.asctime(),'-', "Metadata DB Handler initialized"
開發者ID:Anaconda84,項目名稱:Anaconda,代碼行數:23,代碼來源:MetadataDBHandler.py

示例14: tearDown

 def tearDown(self):
     SQLiteCacheDB.getInstance().close()
     self.datahandler.peers = None
     del self.datahandler
開發者ID:vbit,項目名稱:IJS-stuff,代碼行數:4,代碼來源:test_buddycast.py

示例15: range

        #sys.setcheckinterval(1)
        DEBUG_R = False
        DEBUG = False
        INFO = False
        SLEEP_W = -10 # millisecond. -1 to disable, otherwise indicate how long to sleep
        DO_STH = 0                
        NLOOPS = 1
        total_rlock = total_wlock = 0
        
        for i in range(NLOOPS):
            rlock, wlock = start_testing(nwriters=1, nreaders=0, num_write=100, write_period=5, read_period=5, 
                          db_path=self.db_path, busytimeout=5000, commit=True)
            total_rlock += rlock
            total_wlock += wlock

        db = SQLiteCacheDB.getInstance()
        all = db.fetchall("select * from person")
        if INFO:
            print "Finally inserted", len(all)
            
        assert total_rlock == 0 and total_wlock == 0, (total_rlock, total_wlock)
        assert len(all) > 0, len(all)
        
def test_suite():
    suite = unittest.TestSuite()
    suite.addTest(unittest.makeSuite(TestSqliteCacheDB))
    suite.addTest(unittest.makeSuite(TestThreadedSqliteCacheDB))
    suite.addTest(unittest.makeSuite(TestSQLitePerformance))
    
    return suite
        
開發者ID:Swizec,項目名稱:IJS-stuff,代碼行數:30,代碼來源:test_sqlitecachedb.py


注:本文中的BaseLib.Core.CacheDB.sqlitecachedb.SQLiteCacheDB類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。