【发布时间】:2012-01-10 17:30:45
【问题描述】:
我们以这个类为例,它扩展了 MySQLDB 的连接对象。
class DBHandler(mysql.connections.Connection):
def __init__(self,cursor=None):
if cursor == None:
cursor = 'DictCursor'
super(DBHandler,self).__init__(host = db_host,
user = db_user,
passwd = db_pass,
db = db,
cursorclass=getattr(mysql.cursors, cursor))
def getall(self,q,params=None):
try:
cur = self.cursor()
cur.execute(q,params)
res = cur.fetchall()
return res
except mysql.OperationalError:
#this is the line in question
pass
def execute(self,q,params):
cur = self.cursor()
cur.execute(q,params)
self.commit()
return cur.lastrowid
这个东西很大程度上是为了更简单地访问常见的必需查询。
在标有注释的行中,是否可以在 Python 中调用对象构造函数,即使这是一个成员函数?我使用此示例进行说明,因为如果在运行查询之前超时断开连接,它将有效地重新建立连接。
我知道 MySQLdb 的 ping() 方法,这实际上只是一个能力问题。 在 python 中,是否可以从调用实例的成员函数中调用构造函数来重新初始化该实例?谢谢!
【问题讨论】:
标签: python oop constructor