当前位置: 首页>>代码示例>>Python>>正文


Python sqlalchemy.cast方法代码示例

本文整理汇总了Python中sqlalchemy.cast方法的典型用法代码示例。如果您正苦于以下问题:Python sqlalchemy.cast方法的具体用法?Python sqlalchemy.cast怎么用?Python sqlalchemy.cast使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在sqlalchemy的用法示例。


在下文中一共展示了sqlalchemy.cast方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: get_model_search_filter

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def get_model_search_filter(Model):
    mapper = inspect(Model)

    class ModelSearchFilter(CharFilter):
        def filter(self, qs, value):
            value = self.clean_value(value)
            if value in EMPTY_VALUES:
                return qs

            def map_column(column):
                if isinstance(column.type, (sqlalchemy.Integer, sqlalchemy.Numeric)):
                    return cast(column, sqlalchemy.String).__eq__(value)
                elif isinstance(column.type, sqlalchemy.String):
                    return column.ilike('%{}%'.format(value))
                elif isinstance(column.type, sqlalchemy.JSON):
                    return cast(column, sqlalchemy.String).ilike('%{}%'.format(value))

            operators = list(filter(lambda x: x is not None, map(map_column, mapper.columns)))

            return qs.filter(or_(*operators))

    return ModelSearchFilter 
开发者ID:jet-admin,项目名称:jet-bridge,代码行数:24,代码来源:model_search.py

示例2: _cast

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def _cast(t, expr):
    arg, typ = expr.op().args

    sa_arg = t.translate(arg)
    sa_type = t.get_sqla_type(typ)

    # specialize going from an integer type to a timestamp
    if isinstance(arg.type(), dt.Integer) and isinstance(sa_type, sa.DateTime):
        return sa.func.timezone('UTC', sa.func.to_timestamp(sa_arg))

    if arg.type().equals(dt.binary) and typ.equals(dt.string):
        return sa.func.encode(sa_arg, 'escape')

    if typ.equals(dt.binary):
        #  decode yields a column of memoryview which is annoying to deal with
        # in pandas. CAST(expr AS BYTEA) is correct and returns byte strings.
        return sa.cast(sa_arg, sa.LargeBinary())

    return sa.cast(sa_arg, sa_type) 
开发者ID:ibis-project,项目名称:ibis,代码行数:21,代码来源:compiler.py

示例3: _cast

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def _cast(t, expr):
    arg, typ = expr.op().args

    sa_arg = t.translate(arg)
    sa_type = t.get_sqla_type(typ)

    # specialize going from an integer type to a timestamp
    if isinstance(arg.type(), dt.Integer) and isinstance(sa_type, sa.DateTime):
        return sa.func.timezone('UTC', sa.func.to_timestamp(sa_arg))

    if arg.type().equals(dt.binary) and typ.equals(dt.string):
        return sa.func.encode(sa_arg, 'escape')

    if typ.equals(dt.binary):
        #  decode yields a column of memoryview which is annoying to deal with
        # in pandas. CAST(expr AS BYTEA) is correct and returns byte strings.
        return sa.cast(sa_arg, sa.Binary())

    return sa.cast(sa_arg, sa_type) 
开发者ID:ibis-project,项目名称:ibis,代码行数:21,代码来源:compiler.py

示例4: _variance_reduction

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def _variance_reduction(func_name):
    suffix = {'sample': 'samp', 'pop': 'pop'}

    def variance_compiler(t, expr):
        arg, how, where = expr.op().args

        if arg.type().equals(dt.boolean):
            arg = arg.cast('int32')

        func = getattr(
            sa.func, '{}_{}'.format(func_name, suffix.get(how, 'samp'))
        )

        if where is not None:
            arg = where.ifelse(arg, None)
        return func(t.translate(arg))

    return variance_compiler 
开发者ID:ibis-project,项目名称:ibis,代码行数:20,代码来源:alchemy.py

示例5: test_render_add_index_cast

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def test_render_add_index_cast(self):
        m = MetaData()
        t = Table(
            "test",
            m,
            Column("id", Integer, primary_key=True),
            Column("code", String(255)),
        )
        idx = Index("test_lower_code_idx", cast(t.c.code, String))
        op_obj = ops.CreateIndexOp.from_index(idx)

        eq_ignore_whitespace(
            autogenerate.render_op_text(self.autogen_context, op_obj),
            "op.create_index('test_lower_code_idx', 'test', "
            "[sa.text(!U'CAST(code AS VARCHAR)')], unique=False)",
        ) 
开发者ID:sqlalchemy,项目名称:alembic,代码行数:18,代码来源:test_autogen_render.py

示例6: oql_for_chunk

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def oql_for_chunk(self, chunk, include_self=False, skip=None):
        skip = set(skip or [])
        q = self.items.filter(cast(Item.location, Geometry).contained(envelope(chunk)))

        tags = set()
        for item in q:
            tags |= set(item.tags)
        tags.difference_update(skip_tags)
        tags.difference_update(skip)
        tags = matcher.simplify_tags(tags)
        if not(tags):
            print('no tags, skipping')
            return

        ymin, ymax, xmin, xmax = chunk
        bbox = '{:f},{:f},{:f},{:f}'.format(ymin, xmin, ymax, xmax)

        oql = overpass.oql_for_area(self.overpass_type,
                                    self.osm_id,
                                    tags,
                                    bbox, None,
                                    include_self=include_self)
        return oql 
开发者ID:EdwardBetts,项目名称:osm-wikidata,代码行数:25,代码来源:place.py

示例7: suggest_larger_areas

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def suggest_larger_areas(self):
        ret = []
        for e in reversed(self.is_in() or []):
            osm_type, osm_id, bounds = e['type'], e['id'], e['bounds']
            if osm_type == self.osm_type and osm_id == self.osm_id:
                continue

            box = func.ST_MakeEnvelope(bounds['minlon'], bounds['minlat'],
                                       bounds['maxlon'], bounds['maxlat'], 4326)

            q = func.ST_Area(box.cast(Geography))
            bbox_area = session.query(q).scalar()
            area_in_sq_km = bbox_area / (1000 * 1000)

            if area_in_sq_km < 10 or area_in_sq_km > 40_000:
                continue
            place = Place.from_osm(osm_type, osm_id)
            if not place:
                continue
            place.admin_level = e['tags'].get('admin_level') or None if 'tags' in e else None
            ret.append(place)

        ret.sort(key=lambda place: place.area_in_sq_km)
        return ret 
开发者ID:EdwardBetts,项目名称:osm-wikidata,代码行数:26,代码来源:place.py

示例8: test_view_data_with_map_location

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def test_view_data_with_map_location(self):
        survey_id = (
            self.session
            .query(models.SurveyNode.root_survey_id)
            .filter(
                sa.cast(
                    models.SurveyNode.type_constraint, pg.TEXT
                ) == 'location'
            )
            .scalar()
        )
        url = '/admin/data/' + survey_id
        response = self.fetch(url, method='GET')
        response_soup = BeautifulSoup(response.body, 'html.parser')
        questions = response_soup.findAll('div', {'class': 'question-stats'})
        self.assertEqual(len(questions), 1) 
开发者ID:SEL-Columbia,项目名称:dokomoforms,代码行数:18,代码来源:test_handlers.py

示例9: test_view_data_with_map_facility

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def test_view_data_with_map_facility(self):
        survey_id = (
            self.session
            .query(models.SurveyNode.root_survey_id)
            .filter(
                sa.cast(
                    models.SurveyNode.type_constraint, pg.TEXT
                ) == 'facility'
            )
            .scalar()
        )
        url = '/admin/data/' + survey_id
        response = self.fetch(url, method='GET')
        response_soup = BeautifulSoup(response.body, 'html.parser')
        questions = response_soup.findAll('div', {'class': 'question-stats'})
        self.assertEqual(len(questions), 1) 
开发者ID:SEL-Columbia,项目名称:dokomoforms,代码行数:18,代码来源:test_handlers.py

示例10: test_only_updates_given_table

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def test_only_updates_given_table(
        self,
        session,
        article,
        user,
        connection,
        versioning_manager
    ):
        alter_column(
            connection,
            'user',
            'id',
            lambda value, activity_table: sa.cast(value, sa.Text)
        )
        activity = session.query(versioning_manager.activity_cls).filter_by(
            table_name='article'
        ).one()
        assert isinstance(activity.changed_data['id'], int) 
开发者ID:kvesteri,项目名称:postgresql-audit,代码行数:20,代码来源:test_migration_functions.py

示例11: cast

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def cast(self, type_):
        """Produce a type cast, i.e. ``CAST(<expression> AS <type>)``.

        This is a shortcut to the :func:`_expression.cast` function.

        .. seealso::

            :ref:`coretutorial_casts`

            :func:`_expression.cast`

            :func:`_expression.type_coerce`

        .. versionadded:: 1.0.7

        """
        return Cast(self, type_) 
开发者ID:sqlalchemy,项目名称:sqlalchemy,代码行数:19,代码来源:elements.py

示例12: test_rowid

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def test_rowid(self):
        metadata = self.metadata
        t = Table("t1", metadata, Column("x", Integer))

        with testing.db.begin() as conn:
            t.create(conn)
            conn.execute(t.insert(), {"x": 5})
            s1 = select([t]).subquery()
            s2 = select([column("rowid")]).select_from(s1)
            rowid = conn.scalar(s2)

            # the ROWID type is not really needed here,
            # as cx_oracle just treats it as a string,
            # but we want to make sure the ROWID works...
            rowid_col = column("rowid", oracle.ROWID)
            s3 = select([t.c.x, rowid_col]).where(
                rowid_col == cast(rowid, oracle.ROWID)
            )
            eq_(conn.execute(s3).fetchall(), [(5, rowid)]) 
开发者ID:sqlalchemy,项目名称:sqlalchemy,代码行数:21,代码来源:test_types.py

示例13: bind_expression

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def bind_expression(self, value):
        return cast(value, sqltypes.JSON) 
开发者ID:chanzuckerberg,项目名称:sqlalchemy-aurora-data-api,代码行数:4,代码来源:__init__.py

示例14: cast

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def cast(self, type_):
        """Produce a type cast, i.e. ``CAST(<expression> AS <type>)``.

        This is a shortcut to the :func:`~.expression.cast` function.

        .. versionadded:: 1.0.7

        """
        return Cast(self, type_) 
开发者ID:jpush,项目名称:jbox,代码行数:11,代码来源:elements.py

示例15: list_dids_by_meta

# 需要导入模块: import sqlalchemy [as 别名]
# 或者: from sqlalchemy import cast [as 别名]
def list_dids_by_meta(scope, select, session=None):
    """
    Add or update the given metadata to the given did

    :param scope: the scope of the did
    :param name: the name of the did
    :param meta: the metadata to be added or updated
    """
    # Currently for sqlite only add, get and delete is implemented.
    if session.bind.dialect.name == 'sqlite':
        raise NotImplementedError
    if session.bind.dialect.name == 'oracle':
        oracle_version = int(session.connection().connection.version.split('.')[0])
        if oracle_version < 12:
            raise NotImplementedError

    query = session.query(models.DidMeta)
    if scope is not None:
        query = query.filter(models.DidMeta.scope == scope)

    for k, v in iteritems(select):
        if session.bind.dialect.name == 'oracle':
            query = query.filter(text("json_exists(meta,'$.%s?(@==''%s'')')" % (k, v)))
        else:
            query = query.filter(cast(models.DidMeta.meta[k], String) == type_coerce(v, JSON))
    dids = list()
    for row in query.yield_per(10):
        dids.append({'scope': row.scope, 'name': row.name})
    return dids 
开发者ID:rucio,项目名称:rucio,代码行数:31,代码来源:did.py


注:本文中的sqlalchemy.cast方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。