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


Python types.JSON屬性代碼示例

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


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

示例1: load_dialect_impl

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def load_dialect_impl(self, dialect):
        if dialect.name == 'postgresql':
            return dialect.type_descriptor(JSONB())
        elif dialect.name == 'mysql':
            return dialect.type_descriptor(types.JSON())
        elif dialect.name == 'oracle':
            return dialect.type_descriptor(CLOB())
        else:
            return dialect.type_descriptor(String()) 
開發者ID:rucio,項目名稱:rucio,代碼行數:11,代碼來源:types.py

示例2: _json_deserializer

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def _json_deserializer(self, row):
        """JSON deserializer for RECORD types.

        The DB-API layer already deserializes JSON to a dictionary, so this
        just returns the input.
        """
        return row 
開發者ID:mxmzdlv,項目名稱:pybigquery,代碼行數:9,代碼來源:sqlalchemy_bigquery.py

示例3: set_custom_properties

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def set_custom_properties(self, table):
        model = table.__tablename__
        for property, values in properties["custom"].get(model, {}).items():
            if values.get("private", False):
                kwargs = {}
            else:
                kwargs = {
                    "default": values["default"],
                    "info": {"log_change": values.get("log_change", True)},
                }
            column = self.Column(
                {
                    "boolean": Boolean,
                    "dict": self.Dict,
                    "float": Float,
                    "integer": Integer,
                    "json": JSON,
                    "string": self.LargeString,
                    "select": self.SmallString,
                    "multiselect": self.List,
                }[values.get("type", "string")],
                **kwargs,
            )
            if not values.get("serialize", True):
                self.dont_serialize[model].append(property)
            if not values.get("migrate", True):
                self.dont_migrate[model].append(property)
            setattr(table, property, column)
        return table 
開發者ID:eNMS-automation,項目名稱:eNMS,代碼行數:31,代碼來源:database.py

示例4: string_json_attribute_person_model

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def string_json_attribute_person_model(base):
    """
    This approach to faking JSON support for testing with sqlite is borrowed from:
    https://avacariu.me/articles/2016/compiling-json-as-text-for-sqlite-with-sqlalchemy
    """
    import sqlalchemy.types as types
    import json

    class StringyJSON(types.TypeDecorator):
        """Stores and retrieves JSON as TEXT."""

        impl = types.TEXT

        def process_bind_param(self, value, dialect):
            if value is not None:
                value = json.dumps(value)
            return value

        def process_result_value(self, value, dialect):
            if value is not None:
                value = json.loads(value)
            return value

    # TypeEngine.with_variant says "use StringyJSON instead when
    # connecting to 'sqlite'"
    MagicJSON = types.JSON().with_variant(StringyJSON, 'sqlite')

    class StringJsonAttributePerson(base):

        __tablename__ = 'string_json_attribute_person'

        person_id = Column(Integer, primary_key=True)
        name = Column(String, nullable=False)
        birth_date = Column(DateTime)
        # This model uses a String type for "json_tags" to avoid dependency on a nonstandard SQL type in testing, \
        # while still demonstrating support
        address = Column(MagicJSON)
    yield StringJsonAttributePerson 
開發者ID:miLibris,項目名稱:flask-rest-jsonapi,代碼行數:40,代碼來源:test_sqlalchemy_data_layer.py

示例5: test_json

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_json(self):
        for t in ['json', 'jsonb']:
            self._test(t, sqltypes.JSON) 
開發者ID:cockroachdb,項目名稱:sqlalchemy-cockroachdb,代碼行數:5,代碼來源:test_introspection.py

示例6: test_reflection

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_reflection(self):
        Table("json_test", self.metadata, Column("foo", sqlite.JSON))
        self.metadata.create_all()

        reflected = Table("json_test", MetaData(), autoload_with=testing.db)
        is_(reflected.c.foo.type._type_affinity, sqltypes.JSON)
        assert isinstance(reflected.c.foo.type, sqlite.JSON) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:9,代碼來源:test_sqlite.py

示例7: test_rudimentary_roundtrip

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_rudimentary_roundtrip(self):
        sqlite_json = Table(
            "json_test", self.metadata, Column("foo", sqlite.JSON)
        )

        self.metadata.create_all()

        value = {"json": {"foo": "bar"}, "recs": ["one", "two"]}

        with testing.db.connect() as conn:
            conn.execute(sqlite_json.insert(), foo=value)

            eq_(conn.scalar(select([sqlite_json.c.foo])), value) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:15,代碼來源:test_sqlite.py

示例8: test_extract_subobject

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_extract_subobject(self):
        sqlite_json = Table(
            "json_test", self.metadata, Column("foo", sqlite.JSON)
        )

        self.metadata.create_all()

        value = {"json": {"foo": "bar"}}

        with testing.db.connect() as conn:
            conn.execute(sqlite_json.insert(), foo=value)

            eq_(
                conn.scalar(select([sqlite_json.c.foo["json"]])), value["json"]
            ) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:17,代碼來源:test_sqlite.py

示例9: test_deprecated_serializer_args

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_deprecated_serializer_args(self):
        sqlite_json = Table(
            "json_test", self.metadata, Column("foo", sqlite.JSON)
        )
        data_element = {"foo": "bar"}

        js = mock.Mock(side_effect=json.dumps)
        jd = mock.Mock(side_effect=json.loads)

        with testing.expect_deprecated(
            "The _json_deserializer argument to the SQLite "
            "dialect has been renamed",
            "The _json_serializer argument to the SQLite "
            "dialect has been renamed",
        ):
            engine = engines.testing_engine(
                options=dict(_json_serializer=js, _json_deserializer=jd)
            )
        self.metadata.create_all(engine)

        with engine.begin() as conn:
            conn.execute(sqlite_json.insert(), {"foo": data_element})

            row = conn.execute(select([sqlite_json.c.foo])).first()

            eq_(row, (data_element,))
            eq_(js.mock_calls, [mock.call(data_element)])
            eq_(jd.mock_calls, [mock.call(json.dumps(data_element))]) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:30,代碼來源:test_sqlite.py

示例10: setup

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def setup(self):
        metadata = MetaData()
        self.test_table = Table(
            "test_table",
            metadata,
            Column("id", Integer, primary_key=True),
            Column("test_column", JSON),
        )
        self.jsoncol = self.test_table.c.test_column 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:11,代碼來源:test_types.py

示例11: test_custom_astext_type

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_custom_astext_type(self):
        class MyType(types.UserDefinedType):
            pass

        col = column("x", JSON(astext_type=MyType))

        is_(col["q"].astext.type.__class__, MyType)

        is_(col[("q", "p")].astext.type.__class__, MyType)

        is_(col["q"]["p"].astext.type.__class__, MyType) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:13,代碼來源:test_types.py

示例12: _test_insert_nulljson_into_none_as_null

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def _test_insert_nulljson_into_none_as_null(self, engine):
        with engine.connect() as conn:
            conn.execute(
                self.tables.data_table.insert(),
                {"name": "r1", "nulldata": JSON.NULL},
            )
            self._assert_column_is_JSON_NULL(conn, column="nulldata") 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:9,代碼來源:test_types.py

示例13: test_reflection

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_reflection(self):

        Table("mysql_json", self.metadata, Column("foo", mysql.JSON))
        self.metadata.create_all()

        reflected = Table("mysql_json", MetaData(), autoload_with=testing.db)
        is_(reflected.c.foo.type._type_affinity, sqltypes.JSON)
        assert isinstance(reflected.c.foo.type, mysql.JSON) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:10,代碼來源:test_types.py

示例14: test_rudimental_round_trip

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def test_rudimental_round_trip(self):
        # note that test_suite has many more JSON round trip tests
        # using the backend-agnostic JSON type

        mysql_json = Table(
            "mysql_json", self.metadata, Column("foo", mysql.JSON)
        )
        self.metadata.create_all()

        value = {"json": {"foo": "bar"}, "recs": ["one", "two"]}

        with testing.db.connect() as conn:
            conn.execute(mysql_json.insert(), foo=value)

            eq_(conn.scalar(select([mysql_json.c.foo])), value) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:17,代碼來源:test_types.py

示例15: mutable_json_type

# 需要導入模塊: from sqlalchemy import types [as 別名]
# 或者: from sqlalchemy.types import JSON [as 別名]
def mutable_json_type(dbtype=JSON, nested=False):
    """Type creator for (optionally nested) mutable JSON column types.

    The default backend data type is sqlalchemy.types.JSON, but can be set to
    any other type by providing the `dbtype` parameter.
    """
    mutable_type = NestedMutable if nested else MutableDict
    return mutable_type.as_mutable(dbtype)


# Base mutable JSON types 
開發者ID:edelooff,項目名稱:sqlalchemy-json,代碼行數:13,代碼來源:__init__.py


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