pyodbc连接数据库两次失败

时间:2013-05-15 02:26:58

标签: python sql-server connection pyodbc

我正在尝试使用Python和pyodbc访问SQL Server 2008.第一个连接有效。然后,在程序完成其作业后,它将关闭连接。当程序试图访问数据库并再次连接到它时,它在语句中失败:

self.conn = pyodbc.connect(DRIVER=self.DRIVER, SERVER=self.SERVER, DATABASE=self.DATABASE, UID=self.UID, PWD=self.PWD, charset="UTF-8")

但第一次还可以。那么有谁知道为什么?以下是Python代码:

class ODBC_MS:  

    def __init__(self, DRIVER,SERVER, DATABASE, UID, PWD):
        ''' initialization '''

        self.DRIVER = DRIVER
        self.SERVER = SERVER
        self.DATABASE = DATABASE
        self.UID = UID
        self.PWD = PWD


    def _GetConnect(self):
        ''' Connect to the DB '''
        if not self.DATABASE:
            raise(NameError,"no getting db name")
        try:
            self.conn = pyodbc.connect(DRIVER=self.DRIVER, SERVER=self.SERVER,
                                       DATABASE=self.DATABASE, UID=self.UID,
                                       PWD=self.PWD, charset="UTF-8")
        except Exception,e:
            print e.message
        else:
            self.cur = self.conn.cursor()
            if not self.cur:
                raise(NameError,"connected failed!")
            else:
                return self.cur, self.conn

    def ExecNoQuery(self,conn, cursor, sql):
        cursor.execute(sql)
        ret = conn.commit()
        return ret

    def _UnConnect(self,conn, cursor):
        conn.close()


    if __name__ == '__main__':

    ms = ODBC_MS('{SQL SERVER}', r'<server>', '<db>', '<user>',  '<password>') 
    cursor, conn = ms._GetConnect() #connection

    sql = "create table XX for example"

    ret = ms.ExecNoQuery(conn, cursor,sql) #sql operation


    ms._UnConnect(conn, cursor) #close db


    #access the database the second time.
    ms = ODBC_MS('{SQL SERVER}', r'<server>', '<db>', '<user>',  '<password>') 
    cursor, conn = ms._GetConnect() # not success, I don't know why

    sql = "create table XX for example"
    ret = ms.ExecNoQuery(conn, cursor,sql) #sql operation

    ms._UnConnect(conn, cursor) #close db

第二次程序调用{​​{1}}时,语句ms.GetConnect()失败。

0 个答案:

没有答案