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


Python MySQLdb.ProgrammingError方法代碼示例

本文整理匯總了Python中MySQLdb.ProgrammingError方法的典型用法代碼示例。如果您正苦於以下問題:Python MySQLdb.ProgrammingError方法的具體用法?Python MySQLdb.ProgrammingError怎麽用?Python MySQLdb.ProgrammingError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在MySQLdb的用法示例。


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

示例1: setUp

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def setUp(self):
        _skip_if_no_MySQLdb()
        import MySQLdb
        try:
            # Try Travis defaults.
            # No real user should allow root access with a blank password.
            self.db = MySQLdb.connect(host='localhost', user='root', passwd='',
                                    db='pandas_nosetest')
        except:
            pass
        else:
            return
        try:
            self.db = MySQLdb.connect(read_default_group='pandas')
        except MySQLdb.ProgrammingError as e:
            raise nose.SkipTest(
                "Create a group of connection parameters under the heading "
                "[pandas] in your system's mysql default file, "
                "typically located at ~/.my.cnf or /etc/.my.cnf. ")
        except MySQLdb.Error as e:
            raise nose.SkipTest(
                "Cannot connect to database. "
                "Create a group of connection parameters under the heading "
                "[pandas] in your system's mysql default file, "
                "typically located at ~/.my.cnf or /etc/.my.cnf. ") 
開發者ID:ktraunmueller,項目名稱:Computable,代碼行數:27,代碼來源:test_sql.py

示例2: test_tquery

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def test_tquery(self):
        try:
            import MySQLdb
        except ImportError:
            raise nose.SkipTest("no MySQLdb")
        frame = tm.makeTimeDataFrame()
        drop_sql = "DROP TABLE IF EXISTS test_table"
        cur = self.db.cursor()
        cur.execute(drop_sql)
        sql.write_frame(frame, name='test_table', con=self.db, flavor='mysql')
        result = sql.tquery("select A from test_table", self.db)
        expected = frame.A
        result = Series(result, frame.index)
        tm.assert_series_equal(result, expected)

        try:
            sys.stdout = StringIO()
            self.assertRaises(MySQLdb.ProgrammingError, sql.tquery,
                              'select * from blah', con=self.db)

            self.assertRaises(MySQLdb.ProgrammingError, sql.tquery,
                              'select * from blah', con=self.db, retry=True)
        finally:
            sys.stdout = sys.__stdout__ 
開發者ID:ktraunmueller,項目名稱:Computable,代碼行數:26,代碼來源:test_sql.py

示例3: test_uquery

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def test_uquery(self):
        try:
            import MySQLdb
        except ImportError:
            raise nose.SkipTest("no MySQLdb")
        frame = tm.makeTimeDataFrame()
        drop_sql = "DROP TABLE IF EXISTS test_table"
        cur = self.db.cursor()
        cur.execute(drop_sql)
        sql.write_frame(frame, name='test_table', con=self.db, flavor='mysql')
        stmt = 'INSERT INTO test_table VALUES(2.314, -123.1, 1.234, 2.3)'
        self.assertEqual(sql.uquery(stmt, con=self.db), 1)

        try:
            sys.stdout = StringIO()

            self.assertRaises(MySQLdb.ProgrammingError, sql.tquery,
                              'insert into blah values (1)', con=self.db)

            self.assertRaises(MySQLdb.ProgrammingError, sql.tquery,
                              'insert into blah values (1)', con=self.db,
                              retry=True)
        finally:
            sys.stdout = sys.__stdout__ 
開發者ID:ktraunmueller,項目名稱:Computable,代碼行數:26,代碼來源:test_sql.py

示例4: set_db_data

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def set_db_data(db_call, values):
    """
    Enter data into DB
    """
    db = MySQLdb.connect(host=DB_HOST, port=3306, user=DB_USER, passwd=DB_PW, db=DB_SCHEMA, use_unicode=True,
                         charset="utf8mb4")
    try:
        db_cursor = db.cursor()
        db_cursor.execute(db_call, values)
        db.commit()
        db_cursor.close()
        db.close()
        logger.info("{}: record inserted into DB".format(datetime.now()))
        return None
    except MySQLdb.ProgrammingError as e:
        logger.info("{}: Exception entering data into database".format(datetime.now()))
        logger.info("{}: {}".format(datetime.now(), e))
        return e 
開發者ID:mitche50,項目名稱:NanoTipBot,代碼行數:20,代碼來源:db.py

示例5: check_row_exists

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def check_row_exists(cursor, table, identifiers):
    """
    check a specified row only for existence
    :param cursor: cursor object able to execute queries
    :param table: name of the table to look into
    :param identifiers:
    :return: True if the row exists, False otherwise
    """
    query = "select exists(select 1 from {table} where {values})".format(
        table=table,
        values=" AND ".join(generate_where_segment(identifiers.items())),
    )

    try:
        res = cursor.execute(query)
    except mysql_driver.ProgrammingError as e:
        (errcode, message) = e.args
        if errcode == 1146:
            return ERR_NO_SUCH_TABLE
        else:
            raise e

    exists, = cursor.fetchone()
    return exists == 1 
開發者ID:elmarx,項目名稱:ansible-mysql-query,代碼行數:26,代碼來源:mysql_query.py

示例6: maybe_create_tables

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def maybe_create_tables(self):
        try:
            self.db.get("SELECT COUNT(*) from entries;")
        except MySQLdb.ProgrammingError:
            subprocess.check_call(['mysql',
                                   '--host=' + options.mysql_host,
                                   '--database=' + options.mysql_database,
                                   '--user=' + options.mysql_user,
                                   '--password=' + options.mysql_password],
                                  stdin=open('schema.sql')) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:12,代碼來源:blog.py

示例7: show_create_table

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def show_create_table(instance, db, table, standardize=True):
    """ Get a standardized CREATE TABLE statement

    Args:
    instance - a hostAddr object
    db - the MySQL database to run against
    table - the table on the db database to run against
    standardize - Remove AUTO_INCREMENT=$NUM and similar

    Returns:
    A string of the CREATE TABLE statement
    """
    conn = connect_mysql(instance)
    cursor = conn.cursor()

    try:
        cursor.execute('SHOW CREATE TABLE `{db}`.`{table}`'.format(table=table,
                                                                   db=db))
        ret = cursor.fetchone()['Create Table']
        if standardize is True:
            ret = re.sub('AUTO_INCREMENT=[0-9]+ ', '', ret)
    except MySQLdb.ProgrammingError as detail:
        (error_code, msg) = detail.args
        if error_code != MYSQL_ERROR_NO_SUCH_TABLE:
            raise
        ret = ''

    return ret 
開發者ID:pinterest,項目名稱:mysql_utils,代碼行數:30,代碼來源:mysql_lib.py

示例8: test_bug_2671682

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def test_bug_2671682(self):
        from MySQLdb.constants import ER

        try:
            self.cursor.execute("describe some_non_existent_table")
        except self.connection.ProgrammingError as msg:
            self.assertTrue(str(ER.NO_SUCH_TABLE) in str(msg)) 
開發者ID:PyMySQL,項目名稱:mysqlclient-python,代碼行數:9,代碼來源:test_MySQLdb_capabilities.py

示例9: test_reraise_exception

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def test_reraise_exception(self):
        c = self.cursor
        try:
            c.execute("SELECT x FROM not_existing_table")
        except MySQLdb.ProgrammingError as e:
            self.assertEqual(e.args[0], 1146)
            return
        self.fail("Should raise ProgrammingError") 
開發者ID:PyMySQL,項目名稱:mysqlclient-python,代碼行數:10,代碼來源:test_MySQLdb_capabilities.py

示例10: _crawl

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def _crawl(self, mid, cur):
        """
        抓取並持久化用戶信息
        :param mid: B站用戶id
        :param cur: mysql遊標
        :return: None
        """
        if self._is_member_exist(cur, mid):
            print(f'數據庫中已存在此用戶mid:{mid}, 忽略')
            return
        member_info = self._get_member_by_mid(mid)
        if member_info is None:
            return
        mid = member_info['mid']
        name = member_info['name']
        sign = member_info['sign'].replace("'", "\\\'")
        rank = member_info['rank']
        level = member_info['level']
        jointime = member_info['jointime']
        moral = member_info['moral']
        silence = member_info['silence']
        birthday = member_info['birthday']
        coins = member_info['coins']
        fans_badge = member_info['fans_badge']
        vip_type = member_info['vip']['type']
        vip_status = member_info['vip']['status']
        try:
            cur.execute(f"INSERT INTO bilibili_member "
                        f"(mid, name, sign, `rank`, `level`, jointime, moral, silence, birthday, coins, fans_badge, vip_type, vip_status) "
                        f"VALUES "
                        f"({mid}, '{name}', '{sign}', {rank}, {level}, {jointime}, {moral}, {silence}, '{birthday}', "
                        f"{coins}, {fans_badge}, {vip_type}, {vip_status})"
                        )
            print(f'成功插入用戶數據: {mid}, 當前代理:{self.cur_proxy["https"]}')
        except MySQLdb.ProgrammingError as e:
            print(f'插入用戶: {mid} 數據出錯:{e}')
            raise SqlInsertException(str(e))
        except MySQLdb.IntegrityError:
            print(f'用戶: {mid} 數據已存在,不作插入')
            raise SqlAlreadyExistsException('數據已存在') 
開發者ID:cwjokaka,項目名稱:bilibili_member_crawler,代碼行數:42,代碼來源:worker.py

示例11: _insert_failure_record

# 需要導入模塊: import MySQLdb [as 別名]
# 或者: from MySQLdb import ProgrammingError [as 別名]
def _insert_failure_record(cur, mid, state, remark):
        remark = remark.replace("'", "\\\'")
        try:
            cur.execute(
                "INSERT INTO failure_record (mid, remark, state) "
                f"VALUES ({mid}, '{remark}', '{state}')"
            )
        except MySQLdb.ProgrammingError as e:
            print(f'插入失敗日誌: {mid} 數據出錯:{e}')
        except MySQLdb.IntegrityError:
            print(f'失敗日誌: {mid} 數據已存在,不作插入') 
開發者ID:cwjokaka,項目名稱:bilibili_member_crawler,代碼行數:13,代碼來源:worker.py


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