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


Python Table.select方法代碼示例

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


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

示例1: OOQuery

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
class OOQuery(object):
    def __init__(self, table, foreign_key=None):
        self.fields = None
        self.table = Table(table)
        self._select = self.table.select()
        self.parser = Parser(self.table, foreign_key)

    @property
    def select_on(self):
        if self.parser.joins:
            return self.parser.joins[-1]
        else:
            return self.table

    def select(self, fields=None):
        if fields:
            self.fields = [getattr(self.table, arg) for arg in fields]
            self._select = self.table.select(*self.fields)
        return self

    def where(self, domain):
        where = self.parser.parse(domain)
        self._select = self.select_on.select(*self.fields)
        self._select.where = where
        return self._select
開發者ID:gisce,項目名稱:ooquery,代碼行數:27,代碼來源:ooquery.py

示例2: test_update_subselect

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
 def test_update_subselect(self):
     t1 = Table('t1')
     t2 = Table('t2')
     query_list = t1.update([t1.c], [t2.select(t2.c, where=t2.i == t1.i)])
     query_nolist = t1.update([t1.c], t2.select(t2.c, where=t2.i == t1.i))
     for query in [query_list, query_nolist]:
         self.assertEqual(str(query),
             'UPDATE "t1" SET "c" = ('
             'SELECT "b"."c" FROM "t2" AS "b" WHERE ("b"."i" = "t1"."i"))')
         self.assertEqual(query.params, ())
開發者ID:michaelfarrell76,項目名稱:ExpertmentPlanner2,代碼行數:12,代碼來源:test_update.py

示例3: login_from_id

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
def login_from_id(user_id):
    with Transaction().new_transaction(readonly=True) as t:
        cursor = t.connection.cursor()
        table = Table('res_user')
        cursor.execute(*table.select(table.login,
                where=table.id == user_id))
        return cursor.fetchone()[0]
開發者ID:coopengo,項目名稱:trytond,代碼行數:9,代碼來源:perf_analyzer.py

示例4: test_insert_subselect

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
 def test_insert_subselect(self):
     t1 = Table("t1")
     t2 = Table("t2")
     subquery = t2.select(t2.c1, t2.c2)
     query = t1.insert([t1.c1, t1.c2], subquery)
     self.assertEqual(str(query), 'INSERT INTO "t1" ("c1", "c2") ' 'SELECT "a"."c1", "a"."c2" FROM "t2" AS "a"')
     self.assertEqual(query.params, ())
開發者ID:ernestoluisrojas,項目名稱:ShnergleServer,代碼行數:9,代碼來源:test_insert.py

示例5: __register__

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def __register__(cls, module_name):
        cursor = Transaction().cursor
        model_data = Table('ir_model_data')

        # Migration from 3.0: new tax rates
        if module_name == 'account_nl':
            for old_id, new_id in (
                    ('tva_vente_19_6', 'tva_vente_taux_normal'),
                    ('tva_vente_7', 'tva_vente_taux_intermediaire'),
                    ('tva_vente_intracommunautaire_19_6',
                        'tva_vente_intracommunautaire_taux_normal'),
                    ('tva_vente_intracommunautaire_7',
                        'tva_vente_intracommunautaire_taux_intermediaire'),
                    ('tva_achat_19_6', 'tva_achat_taux_normal'),
                    ('tva_achat_7', 'tva_achat_taux_intermediaire'),
                    ('tva_achat_intracommunautaire_19_6',
                        'tva_achat_intracommunautaire_taux_normal'),
                    ):
                cursor.execute(*model_data.select(model_data.id,
                        where=(model_data.fs_id == new_id)
                        & (model_data.module == module_name)))
                if cursor.fetchone():
                    continue
                cursor.execute(*model_data.update(
                        columns=[model_data.fs_id],
                        values=[new_id],
                        where=(model_data.fs_id == old_id)
                        & (model_data.module == module_name)))

        super(TaxTemplate, cls).__register__(module_name)
開發者ID:FvD,項目名稱:trytond_account_nl,代碼行數:32,代碼來源:account.py

示例6: __register__

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def __register__(cls, module_name):
        TableHandler = backend.get('TableHandler')
        cursor = Transaction().cursor

        super(ProductMedia, cls).__register__(module_name)

        media_table = cls.__table__()

        if TableHandler.table_exist(cursor, 'product_product_imageset'):
            # Migrate data from ProductImageSet table to ProductMedia table
            imageset_table = Table('product_product_imageset')

            cursor.execute(*media_table.insert(
                columns=[
                    media_table.sequence,
                    media_table.product, media_table.template,
                    media_table.static_file,
                ],
                values=imageset_table.select(
                    Literal(10),
                    imageset_table.product, imageset_table.template,
                    imageset_table.image
                )
            ))

            TableHandler.drop_table(
                cursor, 'product.product.imageset', 'product_product_imageset',
                cascade=True
            )
開發者ID:gautampanday,項目名稱:nereid-catalog,代碼行數:31,代碼來源:product.py

示例7: test_0050_query_pagination

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_0050_query_pagination(self):
        """
        Test pagination via `nereid.contrib.QueryPagination.`
        """
        with Transaction().start(DB_NAME, USER, CONTEXT):
            self.setup_defaults()

            # Create a 100 addresses
            for id in xrange(0, 100):
                self.address_obj.create([{
                    'party': self.guest_party,
                    'name': 'User %s' % id,
                }])

            table = Table('party_address')
            select_query = table.select()

            pagination = QueryPagination(
                self.address_obj, select_query, table, page=1, per_page=10
            )

            self.assertEqual(pagination.count, 100)
            self.assertEqual(pagination.pages, 10)
            self.assertEqual(pagination.begin_count, 1)
            self.assertEqual(pagination.end_count, 10)
開發者ID:2cadz,項目名稱:nereid,代碼行數:27,代碼來源:test_pagination.py

示例8: test_in

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_in(self):
        in_ = In(self.table.c1, [self.table.c2, 1, None])
        self.assertEqual(str(in_), '("c1" IN ("c2", %s, %s))')
        self.assertEqual(in_.params, (1, None))

        t2 = Table('t2')
        in_ = In(self.table.c1, t2.select(t2.c2))
        self.assertEqual(str(in_),
            '("c1" IN (SELECT "a"."c2" FROM "t2" AS "a"))')
        self.assertEqual(in_.params, ())

        in_ = In(self.table.c1, t2.select(t2.c2) | t2.select(t2.c3))
        self.assertEqual(str(in_),
            '("c1" IN (SELECT "a"."c2" FROM "t2" AS "a" '
            'UNION SELECT "a"."c3" FROM "t2" AS "a"))')
        self.assertEqual(in_.params, ())
開發者ID:ernestoluisrojas,項目名稱:ShnergleServer,代碼行數:18,代碼來源:test_operators.py

示例9: test_order_query

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
 def test_order_query(self):
     table = Table('t')
     column = Column(table, 'c')
     query = table.select(column)
     self.assertEqual(str(Asc(query)),
         '(SELECT "a"."c" FROM "t" AS "a") ASC')
     self.assertEqual(str(Desc(query)),
         '(SELECT "a"."c" FROM "t" AS "a") DESC')
開發者ID:jefurry,項目名稱:python-sql,代碼行數:10,代碼來源:test_order.py

示例10: test_delete3

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
 def test_delete3(self):
     t1 = Table('t1')
     t2 = Table('t2')
     query = t1.delete(where=(t1.c.in_(t2.select(t2.c))))
     self.assertEqual(str(query),
         'DELETE FROM "t1" WHERE ("c" IN ('
         'SELECT "a"."c" FROM "t2" AS "a"))')
     self.assertEqual(query.params, ())
開發者ID:michaelfarrell76,項目名稱:ExpertmentPlanner2,代碼行數:10,代碼來源:test_delete.py

示例11: test_with

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_with(self):
        t1 = Table('t1')
        w = With(query=t1.select(t1.c1))

        query = self.table.delete(with_=[w],
            where=self.table.c2.in_(w.select(w.c3)))
        self.assertEqual(str(query),
            'WITH a AS (SELECT "b"."c1" FROM "t1" AS "b") '
            'DELETE FROM "t" WHERE ("c2" IN (SELECT "a"."c3" FROM a AS "a"))')
        self.assertEqual(query.params, ())
開發者ID:michaelfarrell76,項目名稱:ExpertmentPlanner2,代碼行數:12,代碼來源:test_delete.py

示例12: test_lateral_select

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_lateral_select(self):
        t1 = Table('t1')
        t2 = Table('t2')
        lateral = Lateral(t2.select(where=t2.id == t1.t2))
        query = From([t1, lateral]).select()

        self.assertEqual(str(query),
            'SELECT * FROM "t1" AS "a", LATERAL '
            '(SELECT * FROM "t2" AS "c" WHERE ("c"."id" = "a"."t2")) AS "b"')
        self.assertEqual(query.params, ())
開發者ID:XasaKura,項目名稱:Xsql,代碼行數:12,代碼來源:test_lateral.py

示例13: test_join_subselect

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
 def test_join_subselect(self):
     t1 = Table('t1')
     t2 = Table('t2')
     select = t2.select()
     join = Join(t1, select)
     join.condition = t1.c == select.c
     with AliasManager():
         self.assertEqual(str(join),
             '"t1" AS "a" INNER JOIN (SELECT * FROM "t2" AS "c") AS "b" '
             'ON ("a"."c" = "b"."c")')
         self.assertEqual(join.params, ())
開發者ID:Shoreray,項目名稱:bss_final,代碼行數:13,代碼來源:test_join.py

示例14: test_with

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_with(self):
        t1 = Table('t1')
        w = With(query=t1.select())

        query = self.table.insert(
            [self.table.c1],
            with_=[w],
            values=w.select())
        self.assertEqual(str(query),
            'WITH "a" AS (SELECT * FROM "t1" AS "b") '
            'INSERT INTO "t" ("c1") SELECT * FROM "a" AS "a"')
        self.assertEqual(query.params, ())
開發者ID:XasaKura,項目名稱:Xsql,代碼行數:14,代碼來源:test_insert.py

示例15: test_with

# 需要導入模塊: from sql import Table [as 別名]
# 或者: from sql.Table import select [as 別名]
    def test_with(self):
        t1 = Table('t1')
        w = With(query=t1.select(t1.c1))

        query = self.table.update(
            [self.table.c2],
            with_=[w],
            values=[w.select(w.c3, where=w.c4 == 2)])
        self.assertEqual(str(query),
            'WITH b AS (SELECT "c"."c1" FROM "t1" AS "c") '
            'UPDATE "t" SET "c2" = (SELECT "b"."c3" FROM b AS "b" '
            'WHERE ("b"."c4" = %s))')
        self.assertEqual(query.params, (2,))
開發者ID:michaelfarrell76,項目名稱:ExpertmentPlanner2,代碼行數:15,代碼來源:test_update.py


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