青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Benjamin

靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
數據加載中……

SQLModel對mysql基本操作

SQLModel,Python中的SQL數據庫,旨在實現簡單性、兼容性和健壯性。
Documentation: https://sqlmodel.tiangolo.com
Source Code: https://github.com/tiangolo/sqlmodel
兼容 FastAPI, Pydantic, SQLAlchemy.可以使用SQLAlchemy、Pydantic里的大部分接口
安裝時自動安裝Pydantic, SQLAlchemy
示例代碼:
from typing import List, Optional
from sqlmodel import Field, Session, SQLModel, create_engine, select,Relationship
"""
設置數據庫參數
"""
MYSQL_DB = 'xhaccount'            #數據庫命
MYSQL_USER = 'root'               #數據庫賬號
MYSQL_PASSWD = '123456'           #數據庫登陸密碼
MYSQL_HOST = '127.0.0.1'          #數據庫地址
MYSQL_POST = 3306                 #端口
basedir = os.path.abspath(os.path.dirname(__file__))          #路徑
SQLALCHEMY_DATABASE_URI = "mysql://%s:%s@%s:%s/%s?charset=utf8" %(
MYSQL_USER, MYSQL_PASSWD, MYSQL_HOST, MYSQL_POST, MYSQL_DB)       # 數據庫連接url
SQLALCHEMY_MIGRATE_REPO = os.path.join(basedir, 'db_repository')  # 設置數據庫遷移保存的文件夾,用來sqlalchemymigrate
class Team(SQLModel, table=True):
    """Team表"""
    id: Optional[int] = Field(default=None, primary_key=True)    #主鍵
    name: str
    headquarters: str
    heroes: List["Hero"] = Relationship(back_populates="team")   #關聯對象
class Hero(SQLModel, table=True):
    """Hero表"""
    id: Optional[int] = Field(default=None, primary_key=True)  #主鍵
    name: str
    secret_name: str
    age: Optional[int] = None
    team_id: Optional[int] = Field(default=None, foreign_key="team.id")  #外鍵
    team: Optional[Team] = Relationship(back_populates="heroes")         #關聯對象
#SQLite不能設置連接池參數
engine = create_engine(SQLALCHEMY_DATABASE_URI, echo=True)
def create_db_and_tables():
    #創建表
    SQLModel.metadata.create_all(engine)
# Code above omitted ??
def create_heroes():
    with Session(engine) as session:
        team_preventers = Team(name="Preventers", headquarters="Sharp Tower")
        team_z_force = Team(name="Z-Force", headquarters="Sister Margaret’s Bar")
        session.add(team_preventers)                        #增加表記錄
        session.add(team_z_force)
        session.commit()                                    #提交
        hero_deadpond = Hero(
            name="Deadpond", secret_name="Dive Wilson", team_id=team_z_force.id
        )
        hero_rusty_man = Hero(
            name="Rusty-Man",
            secret_name="Tommy Sharp",
            age=48,
            team_id=team_preventers.id,
        )
        hero_spider_boy = Hero(name="Spider-Boy", secret_name="Pedro Parqueador")
        session.add(hero_deadpond)
        session.add(hero_rusty_man)
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_deadpond)
        session.refresh(hero_rusty_man)
        session.refresh(hero_spider_boy)
        print("Created hero:", hero_deadpond)
        print("Created hero:", hero_rusty_man)
        print("Created hero:", hero_spider_boy)
def create_heroes_relationships():
    with Session(engine) as session:
        team_preventers = Team(name="Preventers", headquarters="Sharp Tower")
        team_z_force = Team(name="Z-Force", headquarters="Sister Margaret’s Bar")
        hero_deadpond = Hero(
            name="Deadpond", secret_name="Dive Wilson", team=team_z_force
        )
        hero_rusty_man = Hero(
            name="Rusty-Man", secret_name="Tommy Sharp", age=48, team=team_preventers
        )
        hero_spider_boy = Hero(name="Spider-Boy", secret_name="Pedro Parqueador")
        session.add(hero_deadpond)
        session.add(hero_rusty_man)
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_deadpond)
        session.refresh(hero_rusty_man)
        session.refresh(hero_spider_boy)
        print("Created hero:", hero_deadpond)
        print("Created hero:", hero_rusty_man)
        print("Created hero:", hero_spider_boy)
        hero_spider_boy.team = team_preventers
        session.add(hero_spider_boy)
        session.commit()
def update_heroes():
    #更新
    with Session(engine) as session:
        statement = select(Hero).where(Hero.name == "Spider-Boy")
        results = session.exec(statement)
        hero = results.one()
        print("Hero:", hero)
        hero.age = 16
        session.add(hero)
        session.commit()
        session.refresh(hero)
        print("Updated hero:", hero)
def delete_heroes():
    #刪除
    with Session(engine) as session:
        statement = select(Hero).where(Hero.name == "Spider-Youngster")
        results = session.exec(statement)
        hero = results.one()
        print("Hero: ", hero)
        session.delete(hero)
def select_heroes():
    #查詢(單表)
    with Session(engine) as session:
        #hero = session.get(Hero,9001)        #查詢主鍵id值為9001的數據,返回為None
        statement = select(Hero).offset(6).limit(3)   #從第六行開始,最多顯示三行
        # statement = select(Hero.name).where(Hero.age >= 35).where(Hero.age < 40) #條件過濾并且只顯示age字段 這里等于用==符號
        # statement = select(Hero).where(Hero.age >= 35, Hero.age < 40)#條件過濾并且只顯示age字段
        results = session.exec(statement)
        # print("Hero",results.first())      #顯示第一條數據 或者使用results.one()
        for hero in results:
            print(hero)
def select_heroes_mulittable():
    #查詢(多表)
    with Session(engine) as session:
        statement = select(Hero, Team).where(Hero.team_id == Team.id)
        results = session.exec(statement)
        for hero, team in results:
            print("Hero:", hero, "Team:", team)
def create_heroes_useteam():
    #修改表數據(通過其他表數據)
    with Session(engine) as session:
        team_preventers = Team(name="Preventers", headquarters="Sharp Tower")
        team_z_force = Team(name="Z-Force", headquarters="Sister Margaret’s Bar")
        session.add(team_preventers)
        session.add(team_z_force)
        session.commit()
        hero_deadpond = Hero(
            name="Deadpond", secret_name="Dive Wilson", team_id=team_z_force.id
        )
        hero_rusty_man = Hero(
            name="Rusty-Man",
            secret_name="Tommy Sharp",
            age=48,
            team_id=team_preventers.id,
        )
        hero_spider_boy = Hero(name="Spider-Boy", secret_name="Pedro Parqueador")
        session.add(hero_deadpond)
        session.add(hero_rusty_man)
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_deadpond)
        session.refresh(hero_rusty_man)
        session.refresh(hero_spider_boy)
        print("Created hero:", hero_deadpond)
        print("Created hero:", hero_rusty_man)
        print("Created hero:", hero_spider_boy)
        hero_spider_boy.team_id = team_preventers.id
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_spider_boy)
        print("Updated hero:", hero_spider_boy)
def create_heros_read_relationships():
    with Session(engine) as session:
        team_preventers = Team(name="Preventers", headquarters="Sharp Tower")
        team_z_force = Team(name="Z-Force", headquarters="Sister Margaret’s Bar")
        hero_deadpond = Hero(
            name="Deadpond", secret_name="Dive Wilson", team=team_z_force
        )
        hero_rusty_man = Hero(
            name="Rusty-Man", secret_name="Tommy Sharp", age=48, team=team_preventers
        )
        hero_spider_boy = Hero(name="Spider-Boy", secret_name="Pedro Parqueador")
        session.add(hero_deadpond)
        session.add(hero_rusty_man)
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_deadpond)
        session.refresh(hero_rusty_man)
        session.refresh(hero_spider_boy)
        print("Created hero:", hero_deadpond)
        print("Created hero:", hero_rusty_man)
        print("Created hero:", hero_spider_boy)
        hero_spider_boy.team = team_preventers
        session.add(hero_spider_boy)
        session.commit()
        session.refresh(hero_spider_boy)
        print("Updated hero:", hero_spider_boy)
        hero_black_lion = Hero(name="Black Lion", secret_name="Trevor Challa", age=35)
        hero_sure_e = Hero(name="Princess Sure-E", secret_name="Sure-E")
        team_wakaland = Team(
            name="Wakaland",
            headquarters="Wakaland Capital City",
            heroes=[hero_black_lion, hero_sure_e],
        )
        session.add(team_wakaland)
        session.commit()
        session.refresh(team_wakaland)
        print("Team Wakaland:", team_wakaland)
        #一次性創建一行
        hero_tarantula = Hero(name="Tarantula", secret_name="Natalia Roman-on", age=32)
        hero_dr_weird = Hero(name="Dr. Weird", secret_name="Steve Weird", age=36)
        hero_cap = Hero(
            name="Captain North America", secret_name="Esteban Rogelios", age=93
        )
        #分別設置各行
        team_preventers.heroes.append(hero_tarantula)
        team_preventers.heroes.append(hero_dr_weird)
        team_preventers.heroes.append(hero_cap)
        #增加
        session.add(team_preventers)
        #提交
        session.commit()
        #刷新表及緩存
        session.refresh(hero_tarantula)
        session.refresh(hero_dr_weird)
        session.refresh(hero_cap)
        print("Preventers new hero:", hero_tarantula)
        print("Preventers new hero:", hero_dr_weird)
        print("Preventers new hero:", hero_cap)
def select_heros_read_relationships():
    with Session(engine) as session:
        #查詢
        statement = select(Hero).where(Hero.name == "Spider-Boy")
        result = session.exec(statement)
        #獲取查詢結果(一條),可以用first()來替代one()
        hero_spider_boy = result.one()
        statement = select(Team).where(Team.id == hero_spider_boy.id)
        result = session.exec(statement)
        #獲取查詢結果記錄集里的第一條
        team = result.first()
        print("Spider-Boy's team:", team)
        print("Spider-Boy's team again:", hero_spider_boy.team)

posted on 2021-09-04 15:08 Benjamin 閱讀(2068) 評論(0)  編輯 收藏 引用 所屬分類: python

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美1区视频| 欧美国产精品| 国产欧美精品xxxx另类| 亚洲欧美中文字幕| 亚洲愉拍自拍另类高清精品| 欧美三级在线视频| 亚洲小说区图片区| 亚洲综合视频在线| 国产一区av在线| 免费试看一区| 欧美久久在线| 午夜在线一区二区| 欧美一区二区三区啪啪| 在线观看国产精品淫| 亚洲国产1区| 欧美日韩国产另类不卡| 亚洲欧美日韩视频二区| 久久精品午夜| 日韩五码在线| 亚洲欧美日韩爽爽影院| 亚洲国产精品va在线看黑人| 亚洲欧洲日产国产综合网| 国产精品激情av在线播放| 久久久久国产精品厨房| 欧美电影免费观看高清完整版| 国产精品99久久99久久久二8| 亚洲综合第一页| 亚洲精品在线一区二区| 亚洲一区久久久| 亚洲青涩在线| 亚洲欧美日韩精品久久久| 亚洲国产精品传媒在线观看| 宅男噜噜噜66国产日韩在线观看| 国产一区欧美日韩| 9l视频自拍蝌蚪9l视频成人| 精品动漫一区| 亚洲午夜高清视频| 亚洲区在线播放| 国产精品国码视频| 亚洲视频精选| 久久久999精品免费| 亚洲免费观看高清完整版在线观看| 亚洲永久字幕| 在线视频精品一区| 老牛影视一区二区三区| 欧美中文字幕久久| 欧美日韩亚洲免费| 亚洲第一精品在线| 伊人狠狠色丁香综合尤物| 一本色道久久综合狠狠躁的推荐| 亚洲国产成人在线| 久久高清国产| 性欧美video另类hd性玩具| 欧美区日韩区| 亚洲国产精品一区在线观看不卡| 黑人一区二区三区四区五区| 亚洲综合日韩在线| 欧美亚洲视频| 国产精品人人做人人爽| 99国产一区| 一本色道久久综合亚洲精品高清| 免费亚洲一区二区| 亚洲丰满在线| 日韩视频不卡| 欧美区视频在线观看| 亚洲精品国产精品国自产在线 | 亚洲成色www久久网站| 国产亚洲综合精品| 性伦欧美刺激片在线观看| 欧美一区二区三区四区高清| 国产精品草草| 亚洲在线免费视频| 欧美主播一区二区三区| 国产日韩欧美在线视频观看| 亚洲欧美一区二区三区在线| 久久av二区| 国际精品欧美精品| 久久久久中文| 亚洲高清自拍| 亚洲欧美国产77777| 国产欧美精品一区二区三区介绍 | 一区二区三区久久| 午夜精品久久久久久久久久久久| 国产精品毛片在线看| 亚洲综合视频在线| 蜜月aⅴ免费一区二区三区 | 国产一区二区三区视频在线观看| 欧美一区二区在线视频| 欧美黄色一区| 亚洲图片在线观看| 国产日韩一区二区三区在线播放| 欧美一区二区三区四区高清 | 欧美在线观看一区| 在线观看视频一区二区欧美日韩| 欧美成人激情视频免费观看| 亚洲美女少妇无套啪啪呻吟| 亚洲在线视频免费观看| 国产真实久久| 欧美激情综合五月色丁香小说 | 亚洲高清视频一区| 亚洲欧美中文在线视频| 一区精品在线播放| 欧美三日本三级少妇三2023| 午夜激情综合网| 亚洲欧洲一二三| 久久国产精品99精品国产| 亚洲高清一区二区三区| 国产精品www994| 狂野欧美激情性xxxx欧美| 亚洲美女尤物影院| 老鸭窝91久久精品色噜噜导演| 99精品欧美一区二区三区| 国产精品一区二区欧美| 欧美wwwwww| 欧美在现视频| 在线综合亚洲| 亚洲精品国产精品久久清纯直播 | 在线视频日韩精品| 伊人色综合久久天天| 国产精品白丝av嫩草影院| 美女任你摸久久| 欧美一区1区三区3区公司| 日韩一级精品| 亚洲电影自拍| 女人香蕉久久**毛片精品| 欧美一区二区成人6969| 99热这里只有成人精品国产| 国模精品一区二区三区| 国产精品欧美日韩一区| 欧美精品v日韩精品v韩国精品v | 亚洲婷婷在线| 日韩视频精品在线| 91久久视频| 亚洲第一毛片| 欧美激情一区二区三区在线| 美国成人直播| 久久嫩草精品久久久久| 校园春色综合网| 午夜伦欧美伦电影理论片| 在线午夜精品自拍| 一区二区欧美视频| 亚洲精品美女免费| 日韩小视频在线观看| 亚洲人成毛片在线播放女女| 亚洲国产精品久久人人爱蜜臀| 国内精品久久久久久久影视蜜臀| 国产乱码精品一区二区三| 国产九九视频一区二区三区| 国产精品亚洲片夜色在线| 国产精品一区久久久| 国产欧美一区二区精品仙草咪| 国产麻豆日韩| 黄色日韩网站视频| 在线国产精品播放| 亚洲欧洲一区| 中文成人激情娱乐网| 亚洲一区国产| 欧美在线观看www| 久久久久亚洲综合| 欧美jjzz| 亚洲蜜桃精久久久久久久 | 欧美一级网站| 久久久国产亚洲精品| 欧美成人r级一区二区三区| 欧美黑人在线播放| 日韩一级二级三级| 亚洲免费影视第一页| 久久国产免费| 欧美激情综合五月色丁香| 欧美婷婷在线| 韩日视频一区| 一本色道久久88亚洲综合88| 亚洲欧美综合国产精品一区| 久久一区视频| 亚洲精品人人| 欧美一区在线视频| 欧美成人午夜剧场免费观看| 国产精品久久久久一区二区三区共 | 亚洲风情亚aⅴ在线发布| 亚洲精品欧美日韩| 午夜激情亚洲| 欧美国产成人在线| 亚洲天堂久久| 欧美成人一区二区三区| 国产精品视频成人| 亚洲经典在线| 久久不射中文字幕| 亚洲日本电影在线| 欧美在线看片| 国产精品www色诱视频| 在线观看视频一区二区| 亚洲欧美日韩国产中文在线| 欧美成人69av| 午夜一区二区三视频在线观看| 你懂的成人av| 韩日精品在线| 欧美在线视频一区二区| 91久久久在线| 免费永久网站黄欧美| 国产一区二区三区四区|