亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? connections.py

?? python聯接mysql驅動 python聯接mysql驅動
?? PY
字號:
"""This module implements connections for MySQLdb. Presently there isonly one class: Connection. Others are unlikely. However, you mightwant to make your own subclasses. In most cases, you will probablyoverride Connection.default_cursor with a non-standard Cursor class."""import cursorsfrom _mysql_exceptions import Warning, Error, InterfaceError, DataError, \     DatabaseError, OperationalError, IntegrityError, InternalError, \     NotSupportedError, ProgrammingErrorimport types, _mysqldef defaulterrorhandler(connection, cursor, errorclass, errorvalue):    """    If cursor is not None, (errorclass, errorvalue) is appended to    cursor.messages; otherwise it is appended to    connection.messages. Then errorclass is raised with errorvalue as    the value.    You can override this with your own error handler by assigning it    to the instance.    """    error = errorclass, errorvalue    if cursor:        cursor.messages.append(error)    else:        connection.messages.append(error)    del cursor    del connection    raise errorclass, errorvalueclass Connection(_mysql.connection):    """MySQL Database Connection Object"""    default_cursor = cursors.Cursor        def __init__(self, *args, **kwargs):        """        Create a connection to the database. It is strongly recommended        that you only use keyword parameters. Consult the MySQL C API        documentation for more information.        host          string, host to connect                  user          string, user to connect as        passwd          string, password to use        db          string, database to use        port          integer, TCP/IP port to connect to        unix_socket          string, location of unix_socket to use        conv          conversion dictionary, see MySQLdb.converters        connect_timeout          number of seconds to wait before the connection attempt          fails.        compress          if set, compression is enabled        named_pipe          if set, a named pipe is used to connect (Windows only)        init_command          command which is run once the connection is created        read_default_file          file from which default client values are read        read_default_group          configuration group to use from the default file        cursorclass          class object, used to create cursors (keyword only)        use_unicode          If True, text-like columns are returned as unicode objects          using the connection's character set.  Otherwise, text-like          columns are returned as strings.  columns are returned as          normal strings. Unicode objects will always be encoded to          the connection's character set regardless of this setting.        charset          If supplied, the connection character set will be changed          to this character set (MySQL-4.1 and newer). This implies          use_unicode=True.        sql_mode          If supplied, the session SQL mode will be changed to this          setting (MySQL-4.1 and newer). For more details and legal          values, see the MySQL documentation.                  client_flag          integer, flags to use or 0          (see MySQL docs or constants/CLIENTS.py)        ssl          dictionary or mapping, contains SSL connection parameters;          see the MySQL documentation for more details          (mysql_ssl_set()).  If this is set, and the client does not          support SSL, NotSupportedError will be raised.        local_infile          integer, non-zero enables LOAD LOCAL INFILE; zero disables            There are a number of undocumented, non-standard methods. See the        documentation for the MySQL C API for some hints on what they do.        """        from constants import CLIENT, FIELD_TYPE        from converters import conversions        from weakref import proxy, WeakValueDictionary                import types        kwargs2 = kwargs.copy()                if kwargs.has_key('conv'):            conv = kwargs['conv']        else:            conv = conversions        conv2 = {}        for k, v in conv.items():            if isinstance(k, int):                if isinstance(v, list):                    conv2[k] = v[:]                else:                    conv2[k] = v        kwargs2['conv'] = conv2        self.cursorclass = kwargs2.pop('cursorclass', self.default_cursor)        charset = kwargs2.pop('charset', '')        if charset:            use_unicode = True        else:            use_unicode = False                    use_unicode = kwargs2.pop('use_unicode', use_unicode)        sql_mode = kwargs2.pop('sql_mode', '')        client_flag = kwargs.get('client_flag', 0)        client_version = tuple([ int(n) for n in _mysql.get_client_info().split('.')[:2] ])        if client_version >= (4, 1):            client_flag |= CLIENT.MULTI_STATEMENTS        if client_version >= (5, 0):            client_flag |= CLIENT.MULTI_RESULTS                    kwargs2['client_flag'] = client_flag        super(Connection, self).__init__(*args, **kwargs2)        self.encoders = dict([ (k, v) for k, v in conv.items()                               if type(k) is not int ])                self._server_version = tuple([ int(n) for n in self.get_server_info().split('.')[:2] ])        db = proxy(self)        def _get_string_literal():            def string_literal(obj, dummy=None):                return db.string_literal(obj)            return string_literal        def _get_unicode_literal():            def unicode_literal(u, dummy=None):                return db.literal(u.encode(unicode_literal.charset))            return unicode_literal        def _get_string_decoder():            def string_decoder(s):                return s.decode(string_decoder.charset)            return string_decoder                string_literal = _get_string_literal()        self.unicode_literal = unicode_literal = _get_unicode_literal()        self.string_decoder = string_decoder = _get_string_decoder()        if not charset:            charset = self.character_set_name()        self.set_character_set(charset)        if sql_mode:            self.set_sql_mode(sql_mode)        if use_unicode:            self.converter[FIELD_TYPE.STRING].append((None, string_decoder))            self.converter[FIELD_TYPE.VAR_STRING].append((None, string_decoder))            self.converter[FIELD_TYPE.VARCHAR].append((None, string_decoder))            self.converter[FIELD_TYPE.BLOB].append((None, string_decoder))        self.encoders[types.StringType] = string_literal        self.encoders[types.UnicodeType] = unicode_literal        self._transactional = self.server_capabilities & CLIENT.TRANSACTIONS        if self._transactional:            # PEP-249 requires autocommit to be initially off            self.autocommit(False)        self.messages = []            def cursor(self, cursorclass=None):        """        Create a cursor on which queries may be performed. The        optional cursorclass parameter is used to create the        Cursor. By default, self.cursorclass=cursors.Cursor is        used.        """        return (cursorclass or self.cursorclass)(self)    def __enter__(self): return self.cursor()        def __exit__(self, exc, value, tb):        if exc:            self.rollback()        else:            self.commit()                def literal(self, o):        """        If o is a single object, returns an SQL literal as a string.        If o is a non-string sequence, the items of the sequence are        converted and returned as a sequence.        Non-standard. For internal use; do not use this in your        applications.        """        return self.escape(o, self.encoders)    def begin(self):        """Explicitly begin a connection. Non-standard.        DEPRECATED: Will be removed in 1.3.        Use an SQL BEGIN statement instead."""        from warnings import warn        warn("begin() is non-standard and will be removed in 1.3",             DeprecationWarning, 2)        self.query("BEGIN")            if not hasattr(_mysql.connection, 'warning_count'):        def warning_count(self):            """Return the number of warnings generated from the            last query. This is derived from the info() method."""            from string import atoi            info = self.info()            if info:                return atoi(info.split()[-1])            else:                return 0    def set_character_set(self, charset):        """Set the connection character set to charset. The character        set can only be changed in MySQL-4.1 and newer. If you try        to change the character set from the current value in an        older version, NotSupportedError will be raised."""        if self.character_set_name() != charset:            try:                super(Connection, self).set_character_set(charset)            except AttributeError:                if self._server_version < (4, 1):                    raise NotSupportedError, "server is too old to set charset"                self.query('SET NAMES %s' % charset)                self.store_result()        self.string_decoder.charset = charset        self.unicode_literal.charset = charset    def set_sql_mode(self, sql_mode):        """Set the connection sql_mode. See MySQL documentation for        legal values."""        if self._server_version < (4, 1):            raise NotSupportedError, "server is too old to set sql_mode"        self.query("SET SESSION sql_mode='%s'" % sql_mode)        self.store_result()            def show_warnings(self):        """Return detailed information about warnings as a        sequence of tuples of (Level, Code, Message). This        is only supported in MySQL-4.1 and up. If your server        is an earlier version, an empty sequence is returned."""        if self._server_version < (4,1): return ()        self.query("SHOW WARNINGS")        r = self.store_result()        warnings = r.fetch_row(0)        return warnings        Warning = Warning    Error = Error    InterfaceError = InterfaceError    DatabaseError = DatabaseError    DataError = DataError    OperationalError = OperationalError    IntegrityError = IntegrityError    InternalError = InternalError    ProgrammingError = ProgrammingError    NotSupportedError = NotSupportedError    errorhandler = defaulterrorhandler

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线观看一区二区| 精品日韩欧美在线| 一本一本大道香蕉久在线精品 | 日韩精品免费视频人成| 午夜av区久久| 爽爽淫人综合网网站| 免费看精品久久片| 国产一区二区三区四| 国产999精品久久久久久| 成人一区在线观看| 91麻豆福利精品推荐| 色噜噜夜夜夜综合网| 欧美视频在线一区| 欧美一区二区不卡视频| 日韩精品资源二区在线| 久久精品在线观看| 国产精品美女www爽爽爽| 亚洲你懂的在线视频| 亚洲一区二区精品久久av| 五月婷婷色综合| 蜜臀av国产精品久久久久| 国产自产v一区二区三区c| 暴力调教一区二区三区| 91黄视频在线观看| 欧美精品日韩精品| 久久久久久久综合| 亚洲免费看黄网站| 日韩中文字幕不卡| 国产91精品一区二区麻豆网站 | xnxx国产精品| 亚洲婷婷国产精品电影人久久| 亚洲国产精品一区二区久久恐怖片 | 日韩欧美一区中文| 亚洲国产精华液网站w| 一区二区三区精品视频在线| 麻豆一区二区99久久久久| 成人自拍视频在线观看| 欧美性做爰猛烈叫床潮| 日韩一级免费一区| 国产精品九色蝌蚪自拍| 亚洲国产aⅴ成人精品无吗| 久久精品99国产精品日本| 久久久99免费| 一区二区三区四区国产精品| 免费成人av在线| kk眼镜猥琐国模调教系列一区二区| 欧美综合天天夜夜久久| www精品美女久久久tv| 亚洲免费在线电影| 极品少妇一区二区三区精品视频| 97久久超碰国产精品电影| 91精品国产综合久久久久| 国产精品美女久久久久久久| 日本中文一区二区三区| 91丨porny丨首页| 精品国产区一区| 一区二区三区中文字幕电影 | 精品国产伦一区二区三区观看方式| 国产精品久久国产精麻豆99网站| 蜜臀a∨国产成人精品| 日本道色综合久久| 中文字幕成人在线观看| 男人的天堂久久精品| 在线一区二区三区做爰视频网站| 久久―日本道色综合久久| 五月激情综合婷婷| 色呦呦国产精品| 中文字幕第一区二区| 久久91精品国产91久久小草| 欧美三电影在线| 亚洲男人的天堂网| 福利一区二区在线观看| 精品久久久久久综合日本欧美| 亚洲午夜私人影院| av亚洲精华国产精华精华| 久久夜色精品国产噜噜av| 日韩精品一级中文字幕精品视频免费观看 | 91网上在线视频| 国产女主播一区| 国产米奇在线777精品观看| 日韩一区二区三区免费看 | 国产剧情在线观看一区二区| 欧美乱妇一区二区三区不卡视频| 亚洲人成在线播放网站岛国| 成人av网站免费| 国产人伦精品一区二区| 国产自产高清不卡| 精品国产一区二区三区忘忧草| 免费在线观看精品| 欧美一区二区三区视频在线 | 欧美精品丝袜中出| 亚洲成av人在线观看| 欧美日韩精品欧美日韩精品一 | 国产黑丝在线一区二区三区| 久久综合狠狠综合久久综合88 | 在线观看亚洲成人| 一区二区三区日韩| 欧美在线看片a免费观看| 亚洲精品国产无天堂网2021 | 精品国产一区二区三区久久影院 | 亚洲综合色自拍一区| 色婷婷精品久久二区二区蜜臂av| 亚洲丝袜制服诱惑| 97se亚洲国产综合自在线观| 综合av第一页| 在线观看日韩国产| 午夜在线电影亚洲一区| 欧美精品乱码久久久久久| 人人超碰91尤物精品国产| 欧美一级日韩不卡播放免费| 极品少妇xxxx精品少妇| 久久婷婷一区二区三区| 国产aⅴ综合色| 亚洲嫩草精品久久| 在线成人午夜影院| 美女视频黄久久| 久久精品视频一区二区三区| 成人91在线观看| 亚洲精品日产精品乱码不卡| 欧美性感一类影片在线播放| 日产欧产美韩系列久久99| 欧美变态tickling挠脚心| 国产精品18久久久久久久久久久久| 国产欧美一区二区三区沐欲 | 日韩毛片一二三区| 在线免费亚洲电影| 免播放器亚洲一区| 日本一区二区三区视频视频| 91免费在线看| 日韩经典一区二区| 国产视频一区不卡| 在线视频亚洲一区| 九九精品视频在线看| 国产精品护士白丝一区av| 欧美亚洲日本一区| 韩国精品主播一区二区在线观看| 国产精品天天看| 欧美二区乱c少妇| 国产自产视频一区二区三区| 亚洲人成人一区二区在线观看| 欧美三级资源在线| 国产成人在线视频网址| 一区二区三区四区中文字幕| 欧美电影免费观看完整版| 不卡的av在线| 老司机免费视频一区二区| 国产精品久久久久久亚洲伦 | 亚洲国产精品一区二区www在线| 日韩女优毛片在线| 色婷婷国产精品久久包臀| 韩国成人精品a∨在线观看| 亚洲同性gay激情无套| 欧美α欧美αv大片| 日本道精品一区二区三区| 国产一区二三区好的| 亚洲第一成人在线| 国产色91在线| 91精品国产高清一区二区三区蜜臀| 成人综合婷婷国产精品久久蜜臀| 免费久久99精品国产| 中文字幕中文乱码欧美一区二区| 欧美一区欧美二区| 91片在线免费观看| 国产精品中文字幕日韩精品| 天天综合天天做天天综合| 国产精品麻豆一区二区| 日韩欧美123| 欧美乱妇20p| 97精品电影院| 成人午夜碰碰视频| 久久91精品国产91久久小草| 亚洲第一电影网| 亚洲精品视频在线| 国产女人水真多18毛片18精品视频| 91精品国产入口在线| 欧美亚洲图片小说| 一道本成人在线| 不卡欧美aaaaa| 福利一区二区在线| 日韩亚洲欧美成人一区| 在线亚洲一区观看| 91视频免费观看| 国产乱人伦精品一区二区在线观看| 日韩成人免费在线| 亚洲国产sm捆绑调教视频| 亚洲欧美色一区| 国产精品大尺度| 国产精品久久久久婷婷| 国产亚洲自拍一区| 精品国产电影一区二区| 日韩一区二区三| 欧美一区二区免费| 欧美一区二区三区的| 在线不卡欧美精品一区二区三区| 欧美日韩亚洲高清一区二区| 欧美无砖专区一中文字| 91福利视频网站| 在线免费观看不卡av| 色激情天天射综合网| 色婷婷国产精品|