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


Python psycopg2.DataError方法代碼示例

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


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

示例1: test_transaction_point_oldstyle

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_transaction_point_oldstyle(engine):
    async with engine.acquire() as cur:
        tr = Transaction(cur, IsolationLevel.read_committed)
        await tr.begin()

        await cur.execute("insert into tbl values(1, 'data')")

        try:
            await tr.savepoint()
            await cur.execute("insert into tbl values(1/0, 'no data')")
        except psycopg2.DataError:
            await tr.rollback_savepoint()

        await tr.savepoint()
        await cur.execute("insert into tbl values(2, 'data')")
        await tr.release_savepoint()

        await cur.execute("insert into tbl values(3, 'data')")

        resp = await cur.execute('select * from tbl')
        row = await resp.fetchall()
        assert row == [(22, 'read only'), (1, 'data'), (2, 'data'),
                       (3, 'data')]

        await tr.commit() 
開發者ID:aio-libs,項目名稱:aiopg,代碼行數:27,代碼來源:test_transaction.py

示例2: test_transaction_point

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_transaction_point(engine):
    async with engine.cursor() as cur:
        async with Transaction(cur, IsolationLevel.read_committed) as tr:
            await cur.execute("insert into tbl values(1, 'data')")

            with pytest.raises(psycopg2.DataError):
                async with tr.point():
                    await cur.execute("insert into tbl values(1/0, 'data')")

            async with tr.point():
                await cur.execute("insert into tbl values(2, 'data point')")

            await cur.execute("insert into tbl values(3, 'data')")

            await cur.execute('select * from tbl')
            row = await cur.fetchall()
            assert row == [(22, 'read only'), (1, 'data'),
                           (2, 'data point'), (3, 'data')] 
開發者ID:aio-libs,項目名稱:aiopg,代碼行數:20,代碼來源:test_async_transaction.py

示例3: test_begin_nested

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_begin_nested(engine):
    async with engine.cursor() as cur:
        async with cur.begin_nested():
            await cur.execute("insert into tbl values(1, 'data')")

            with pytest.raises(psycopg2.DataError):
                async with cur.begin_nested():
                    await cur.execute("insert into tbl values(1/0, 'no data')")

            async with cur.begin_nested():
                await cur.execute("insert into tbl values(2, 'data')")

        async with cur.begin_nested():
            await cur.execute('select * from tbl')
            row = await cur.fetchall()
            assert row == [(22, 'read only'), (1, 'data'),
                           (2, 'data'), ] 
開發者ID:aio-libs,項目名稱:aiopg,代碼行數:19,代碼來源:test_async_transaction.py

示例4: forms

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def forms(w):
        """ Return a list of all possible forms of a particular root (stem) """
        c = Meanings._cursor
        assert c is not None
        m = None
        try:
            c.execute(Meanings._DB_Q_FORMS, [w])
            # Map the returned data from fetchall() to a list of instances
            # of the BIN_Meaning namedtuple
            g = c.fetchall()
            if g is not None:
                m = list(map(BIN_Meaning._make, g))
        except (psycopg2.DataError, psycopg2.ProgrammingError) as e:
            print("Word '{0}' caused DB exception {1}".format(w, e))
            m = None
        return m 
開發者ID:mideind,項目名稱:Greynir,代碼行數:18,代碼來源:vocab.py

示例5: sentences

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def sentences(self):
        """ Return a list of all test sentences in the database """
        assert self._c is not None
        m = [ ]
        try:
            self._c.execute("SELECT id, sentence, numtrees, best, target FROM sentences ORDER BY id;")
            t = self._c.fetchall()
            m = [ dict(
                    identity = r[0],
                    sentence = r[1],
                    numtrees = r[2],
                    best = r[3],
                    target = r[4])
                for r in t]
        except psycopg2.DataError as e:
            # Fall through with empty m
            pass
        return m 
開發者ID:mideind,項目名稱:Greynir,代碼行數:20,代碼來源:ptest.py

示例6: insert_rows

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def insert_rows(self, rows, table_name=None):
        """
        Inserts many rows, all in the same transaction, using psycopg2.extras.execute_values
        """

        if table_name is None:
            table_name = self.table_name

        with self.conn.cursor() as curs:
            sql_str, template = sql.insert_many(table_name, rows)
            try:
                psycopg2.extras.execute_values(
                    curs,
                    sql_str,
                    rows,
                    template=template,
                    page_size=len(rows)
                )
            except psycopg2.DataError:
                print(rows) # useful for debugging
                raise
        self.conn.commit() 
開發者ID:nycdb,項目名稱:nycdb,代碼行數:24,代碼來源:database.py

示例7: vfolder_check_exists

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def vfolder_check_exists(handler: Callable[..., Awaitable[web.Response]]):
    '''
    Checks if the target vfolder exists and is owned by the current user.

    The decorated handler should accept an extra "row" argument
    which contains the matched VirtualFolder table row.
    '''

    @functools.wraps(handler)
    async def _wrapped(request: web.Request, *args, **kwargs) -> web.Response:
        dbpool = request.app['dbpool']
        user_uuid = request['user']['uuid']
        folder_name = request.match_info['name']
        async with dbpool.acquire() as conn:
            j = sa.join(
                vfolders, vfolder_permissions,
                vfolders.c.id == vfolder_permissions.c.vfolder, isouter=True)
            query = (
                sa.select('*')
                .select_from(j)
                .where(((vfolders.c.user == user_uuid) |
                        (vfolder_permissions.c.user == user_uuid)) &
                       (vfolders.c.name == folder_name)))
            try:
                result = await conn.execute(query)
            except psycopg2.DataError:
                raise InvalidAPIParameters
            row = await result.first()
            if row is None:
                raise VFolderNotFound()
        return await handler(request, row, *args, **kwargs)

    return _wrapped 
開發者ID:lablup,項目名稱:backend.ai-manager,代碼行數:35,代碼來源:vfolder.py

示例8: parse

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def parse(self, s, curs):
        if s is None:
            return None

        tokens = self.tokenize(s)
        if len(tokens) != len(self.atttypes):
            raise psycopg2.DataError(
                "expecting %d components for the type %s, %d found instead" %
                (len(self.atttypes), self.name, len(tokens)))

        values = [curs.cast(oid, token)
            for oid, token in zip(self.atttypes, tokens)]

        return self.make(values) 
開發者ID:tryolabs,項目名稱:aws-workshop,代碼行數:16,代碼來源:extras.py

示例9: test_path_invalid_repo_name_and_job_name

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_path_invalid_repo_name_and_job_name(self):
        try:
            self.get('/v2/hello/world', self.get_project_headers())
        except psycopg2.DataError:
            pass 
開發者ID:SAP,項目名稱:InfraBox,代碼行數:7,代碼來源:test.py

示例10: test_insertErr

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_insertErr(self):
		key = len(TEST_DATA) + 2
		self.assertRaises((ValueError, psycopg2.DataError), self.tree.insert, 'wat', 1) 
開發者ID:fake-name,項目名稱:IntraArchiveDeduplicator,代碼行數:5,代碼來源:Test_db_BKTree.py

示例11: test_parse_incomplete_date

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_parse_incomplete_date(self):
        self.assertRaises(psycopg2.DataError, self.DATE, '2007', self.curs)
        self.assertRaises(psycopg2.DataError, self.DATE, '2007-01', self.curs) 
開發者ID:synthetichealth,項目名稱:syntheticmass,代碼行數:5,代碼來源:test_dates.py

示例12: test_parse_incomplete_time

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_parse_incomplete_time(self):
        self.assertRaises(psycopg2.DataError, self.TIME, '13', self.curs)
        self.assertRaises(psycopg2.DataError, self.TIME, '13:30', self.curs) 
開發者ID:synthetichealth,項目名稱:syntheticmass,代碼行數:5,代碼來源:test_dates.py

示例13: test_parse_incomplete_datetime

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def test_parse_incomplete_datetime(self):
        self.assertRaises(psycopg2.DataError,
                          self.DATETIME, '2007', self.curs)
        self.assertRaises(psycopg2.DataError,
                          self.DATETIME, '2007-01', self.curs)
        self.assertRaises(psycopg2.DataError,
                          self.DATETIME, '2007-01-01 13', self.curs)
        self.assertRaises(psycopg2.DataError,
                          self.DATETIME, '2007-01-01 13:30', self.curs) 
開發者ID:synthetichealth,項目名稱:syntheticmass,代碼行數:11,代碼來源:test_dates.py

示例14: testFloatInf

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def testFloatInf(self):
        try:
            self.execute("select 'inf'::float")
        except psycopg2.DataError:
            return self.skipTest("inf::float not available on the server")
        except ValueError:
            return self.skipTest("inf not available on this platform")
        s = self.execute("SELECT %s AS foo", (float("inf"),))
        self.failUnless(str(s) == "inf", "wrong float quoting: " + str(s))      
        self.failUnless(type(s) == float, "wrong float conversion: " + repr(s))

        s = self.execute("SELECT %s AS foo", (float("-inf"),))
        self.failUnless(str(s) == "-inf", "wrong float quoting: " + str(s)) 
開發者ID:synthetichealth,項目名稱:syntheticmass,代碼行數:15,代碼來源:test_types_basic.py

示例15: testArrayMalformed

# 需要導入模塊: import psycopg2 [as 別名]
# 或者: from psycopg2 import DataError [as 別名]
def testArrayMalformed(self):
        curs = self.conn.cursor()
        ss = ['', '{', '{}}', '{' * 20 + '}' * 20]
        for s in ss:
            self.assertRaises(psycopg2.DataError,
                psycopg2.extensions.STRINGARRAY, b(s), curs) 
開發者ID:synthetichealth,項目名稱:syntheticmass,代碼行數:8,代碼來源:test_types_basic.py


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