异步orm+pydantic=ormantic

ormantic的Python项目详细描述


正常

ormantic包是python的异步orm,支持postgres, mysql和sqlite。ormatic是来自^{}的fork,用于 与^{}集成,并使用:

因为orm是基于sqlalchemy核心构建的,所以可以使用alembic提供 数据库迁移。

note:使用ipython从控制台尝试此操作,因为它支持await

importdatabasesimportsqlalchemyimportormanticasormdatabase=databases.Database("sqlite:///db.sqlite")metadata=sqlalchemy.MetaData()classNote(orm.Model):id:orm.Integer(primary_key=True)=Nonetext:orm.String(max_length=100)completed:orm.Boolean()=FalseclassMapping:table_name="notes"database=databasemetadata=metadata# Create the databaseengine=sqlalchemy.create_engine(str(database.url))metadata.create_all(engine)# .create()awaitNote.objects.create(text="Buy the groceries.",completed=False)awaitNote.objects.create(text="Call Mum.",completed=True)awaitNote.objects.create(text="Send invoices.",completed=True)# .all()notes=awaitNote.objects.all()# .filter()notes=awaitNote.objects.filter(completed=True).all()# exact, iexact, contains, icontains, lt, lte, gt, gte, innotes=awaitNote.objects.filter(text__icontains="mum").all()# .get()note=awaitNote.objects.get(id=1)# .update()awaitnote.update(completed=True)# .delete()awaitnote.delete()note=awaitNote.objects.get(id=2)assertnote.pk==note.id==2

ormantic支持在外键之间加载和筛选…

importdatabasesimportsqlalchemyimportormanticasormdatabase=databases.Database("sqlite:///db.sqlite")metadata=sqlalchemy.MetaData()classAlbum(orm.Model):id:orm.Integer(primary_key=True)=Nonename:orm.String(max_length=100)classMapping:table_name="album"metadata=metadatadatabase=databaseclassTrack(orm.Model):id:orm.Integer(primary_key=True)=Nonealbum:orm.ForeignKey(Album)title:orm.String(max_length=100)position:orm.Integer()classMapping:table_name="track"metadata=metadatadatabase=database# Create the databaseengine=sqlalchemy.create_engine(str(database.url))metadata.create_all(engine)# Create some records to work with.malibu=awaitAlbum.objects.create(name="Malibu")awaitTrack.objects.create(album=malibu,title="The Bird",position=1)awaitTrack.objects.create(album=malibu,title="Heart don't stand a chance",position=2)awaitTrack.objects.create(album=malibu,title="The Waters",position=3)fantasies=awaitAlbum.objects.create(name="Fantasies")awaitTrack.objects.create(album=fantasies,title="Help I'm Alive",position=1)awaitTrack.objects.create(album=fantasies,title="Sick Muse",position=2)# Fetch an instance, without loading a foreign key relationship on it.track=awaitTrack.objects.get(title="The Bird")# We have an album instance, but it only has the primary key populatedprint(track.album)# Album(id=1) [sparse]print(track.album.pk)# 1print(track.album.name)# Raises AttributeError# Load the relationship from the databaseawaittrack.album.load()asserttrack.album.name=="Malibu"# This time, fetch an instance, loading the foreign key relationship.track=awaitTrack.objects.select_related("album").get(title="The Bird")asserttrack.album.name=="Malibu"# Fetch instances, with a filter across an FK relationship.tracks=Track.objects.filter(album__name="Fantasies")assertlen(tracks)==2# Fetch instances, with a filter and operator across an FK relationship.assertTrack.objects.filter(album__name__iexact="fantasies").count()==2

数据类型

所有字段类型都支持以下关键字参数。

  • primary_key
  • allow_null
  • index
  • unique

支持以下列类型:

  • orm.Boolean()
  • orm.Date()
  • orm.DateTime()
  • orm.Enum()
  • orm.Float()
  • orm.Integer()
  • orm.JSON()
  • orm.String(max_length)
  • orm.StringArray()
  • orm.Text()
  • orm.Time()

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java Spring使用XML配置重试DAO调用   javasocket编程:消息传递顺序   Java ArrayList从两个列表中删除重复项   java在安卓中每次从数组中获取唯一的编号   java为什么collect方法中的双消费者组合器代码永远无法到达?   java类型实例化和声明在同一行   如何在Java应用程序中获取映射网络驱动器的UNC路径   Javascript(GraalJS)与Java中未签名的右移>>>>   xml Java SAX ContentHandler为每个根节点创建新对象   模拟类的java问题   JavaWebapplet可以和离线applet做同样的事情吗?   在Java中设置Windows系统路径   如何导入jwt。io Java库到JMeter   java Simple Kafka消费者未接收消息   带有GoogleAPI错误的Java Jsoup:状态503   java是否可以通过google plus SignIn检索用户信息而不包括google脚本   Java3D洪水填充