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


Python associationproxy.ASSOCIATION_PROXY屬性代碼示例

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


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

示例1: _get_orm_descriptors

# 需要導入模塊: from sqlalchemy.ext import associationproxy [as 別名]
# 或者: from sqlalchemy.ext.associationproxy import ASSOCIATION_PROXY [as 別名]
def _get_orm_descriptors(cls):
        """Return a dictionary with all ORM descriptor names as keys, and
        their types (TEXT, DateTime, etc.) as values.

        """
        # The descriptor needs to be invoked once (using __get__) in order
        # to have access to its attributes (e.g. `remote_attr`)
        all_descs = {name: desc.__get__(None, cls)
                     for name, desc in inspect(cls).all_orm_descriptors.items()
                     if not name.startswith('_')}
        attrs_dict = dict()

        for name, desc in all_descs.items():
            extension_type = _get_extension_type(desc)
            if extension_type is ASSOCIATION_PROXY:
                # Association proxies must be followed to get their type
                while not desc.remote_attr.is_attribute:
                    desc = desc.remote_attr

                # Get the type of the remote attribute
                attrs_dict[name] = desc.remote_attr.expression.type
            elif extension_type is HYBRID_PROPERTY:
                attrs_dict[name] = desc.type

        return attrs_dict 
開發者ID:cloudify-cosmo,項目名稱:cloudify-manager,代碼行數:27,代碼來源:models_base.py

示例2: __init__

# 需要導入模塊: from sqlalchemy.ext import associationproxy [as 別名]
# 或者: from sqlalchemy.ext.associationproxy import ASSOCIATION_PROXY [as 別名]
def __init__(self, name, obj, view_class):
        self.name = name
        self.obj = obj
        self.view_class = view_class
        self.src_class = self.view_class.model
        if isinstance(obj, RelationshipProperty):
            self.direction = self.rel_direction
            self.tgt_class = self.rel_tgt_class
        elif obj.extension_type is ASSOCIATION_PROXY:
            self.direction = self.proxy_direction
            self.tgt_class = self.proxy_tgt_class 
開發者ID:colinhiggs,項目名稱:pyramid-jsonapi,代碼行數:13,代碼來源:__init__.py

示例3: filter_non_model_columns

# 需要導入模塊: from sqlalchemy.ext import associationproxy [as 別名]
# 或者: from sqlalchemy.ext.associationproxy import ASSOCIATION_PROXY [as 別名]
def filter_non_model_columns(data, model):
    """Return the attributes from data which are model columns.

    :param data: The dict containing the data to filter.
    :param model: The model who's column names are used when filtering data.
    :returns: A new dict who's keys are columns in model or are association
        proxies of the model.
    """
    mapper = sqlalchemy.inspect(model)
    columns = set(c.name for c in mapper.columns)
    columns.update(d.value_attr for d in mapper.all_orm_descriptors
                   if d.extension_type is ASSOCIATION_PROXY)
    return dict((k, v) for (k, v)
                in data.items() if k in columns) 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:16,代碼來源:utils.py

示例4: _get_col_types

# 需要導入模塊: from sqlalchemy.ext import associationproxy [as 別名]
# 或者: from sqlalchemy.ext.associationproxy import ASSOCIATION_PROXY [as 別名]
def _get_col_types(cls):

        # Must use private attributes so that they are not shared by subclasses
        if hasattr(cls, "__columns") and hasattr(cls, "__hybrids") and hasattr(cls, "__relationships"):
            return cls.__columns, cls.__hybrids, cls.__relationships

        mapper = inspect(cls)

        cls.__columns = []
        cls.__hybrids = []
        cls.__relationships = {}
        for k, v in mapper.relationships.items():
            cls.__relationships[k] = {}
            cls.__relationships[k]["join_class"] = v.argument
            cls.__relationships[k]["remote_side_column"] = list(v.remote_side)[0]

        for k, c in mapper.all_orm_descriptors.items():

            if k == "__mapper__":
                continue

            if c.extension_type == ASSOCIATION_PROXY:
                continue

            if c.extension_type == HYBRID_PROPERTY:
                cls.__hybrids.append(k)
            elif k not in mapper.relationships:
                cls.__columns.append(k)

        return cls.__columns, cls.__hybrids, cls.__relationships 
開發者ID:MolSSI,項目名稱:QCFractal,代碼行數:32,代碼來源:sql_base.py

示例5: configure_events

# 需要導入模塊: from sqlalchemy.ext import associationproxy [as 別名]
# 或者: from sqlalchemy.ext.associationproxy import ASSOCIATION_PROXY [as 別名]
def configure_events(self):
        @event.listens_for(self.base, "mapper_configured", propagate=True)
        def model_inspection(mapper, model):
            name = model.__tablename__
            for col in inspect(model).columns:
                if not col.info.get("model_properties", True):
                    continue
                model_properties[name].append(col.key)
                if col.type == PickleType and isinstance(col.default.arg, list):
                    property_types[col.key] = "list"
                else:
                    column_type = {
                        Boolean: "bool",
                        Integer: "int",
                        Float: "float",
                        JSON: "dict",
                        PickleType: "dict",
                    }.get(type(col.type), "str")
                    if col.key not in property_types:
                        property_types[col.key] = column_type
            for descriptor in inspect(model).all_orm_descriptors:
                if descriptor.extension_type is ASSOCIATION_PROXY:
                    property = (
                        descriptor.info.get("name")
                        or f"{descriptor.target_collection}_{descriptor.value_attr}"
                    )
                    model_properties[name].append(property)
            if hasattr(model, "parent_type"):
                model_properties[name].extend(model_properties[model.parent_type])
            if "service" in name and name != "service":
                model_properties[name].extend(model_properties["service"])
            models.update({name: model, name.lower(): model})
            model_properties[name].extend(model.model_properties)
            model_properties[name] = list(set(model_properties[name]))
            for relation in mapper.relationships:
                if getattr(relation.mapper.class_, "private", False):
                    continue
                property = str(relation).split(".")[1]
                relationships[name][property] = {
                    "model": relation.mapper.class_.__tablename__,
                    "list": relation.uselist,
                } 
開發者ID:eNMS-automation,項目名稱:eNMS,代碼行數:44,代碼來源:database.py


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