2016-04-27 89 views
0
class DatabaseManager(object): ##Ignore the indentation## 
def __init__(self, db): 
    self.conn = sqlite3.connect(db) 
    self.conn.execute('pragma foreign_keys = on') 
    self.conn.commit() 
    self.c = self.conn.cursor() 


def query_params(self, arg, params=None): 
    self.c.execute(arg, params) 
    self.conn.commit() 
    return self.c 

def query(self, arg): 
    self.c.execute(arg) 
    self.conn.commit() 
    return self.c 

def fetch(self): 
    self.c.fetchall() 
    self.conn.commit() 
    return self.c 

def __del__(self): 
    self.conn.close() 

dbmgr = DatabaseManager("connect.db") 

其他代碼 .... .... .... 然後:接收表信息打印到控制檯

def read_from_db(): 

    tables = [] 
    query = "SELECT name FROM sqlite_master WHERE type='table'" 
    dbmgr.query(query) 
    rows = dbmgr.fetch() 
    for row in rows: 
     tables.append(row) 
    print (tables) 

我不能弄清楚如何查看我的數據庫中的表格,它們是真實的,因爲我可以在我的sqlite管理器中看到它們。這用來工作的時候,我沒有階級,只是做了:

def read_from_db(): 

    tables = [] 
    c.execute("SELECT name FROM sqlite_master WHERE type='table'") 
    rows = c.fetchall() 
    for row in rows: 
     tables.append(row) 
    print (tables) 

回答

1

所以,你獲取的結果,但從來沒有用它做任何事情,然後返回用過的光標...

def fetch(self): 
    self.c.fetchall() # this returns a list of your data 
    self.conn.commit() 
    return self.c 

它也不清楚你在函數

比較你的其他代碼犯什麼,

rows = c.fetchall() 

所以,你應該只需要

def fetch(self): 
    return self.c.fetchall() 

然後調用它

tables = dbmgr.fetch() 

,或者

tables = dbmgr.query(query).fetchall() 

注意,你正在一個空列表,然後添加列表的元素到名單。您可以通過直接分配表來簡化該過程