校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > python實現sqlalchemy的使用概述

python實現sqlalchemy的使用概述

熱門標簽:宿遷星美防封電銷卡 西藏房產智能外呼系統要多少錢 地圖標注審核表 ai電銷機器人源碼 湛江智能外呼系統廠家 外呼并發線路 長沙高頻外呼系統原理是什么 ai電話機器人哪里好 百度地圖標注沒有了

sqlAlchemy解讀: https://www.jb51.net/article/174565.htm

sqlAlchemy解讀:https://www.jb51.net/article/173950.htm

特點是操縱Python對象而不是SQL查詢,也就是在代碼層面考慮的是對象,而不是SQL,體現的是一種程序化思維,這樣使得Python程序更加簡潔易懂。

具體的實現方式是將數據庫表轉換為Python類,其中數據列作為屬性,數據庫操作作為方法。

  1. abstract # 輔助sqlAlchemy實現類的繼承,自動繼承屬性,省去super()
  2. SQLAlchemy定義的ORM,在繼承父級ORM時候,Foreign Key外鍵是不能繼承的,它強制要求在子類中重新定義。

使用概述

在使用sqlalchemy訪問數據庫的時候,以類的形式表示表格,因此在使用之前,需要先定義類。

類的定義有三種:基類BASE、父類、子類

基類是sqlalchemy底層的;當需要一份數據切分為多個子表的時候,或多個表的字段一致時,可以使用一個父類定義字段的類型,多個子表繼承父類的屬性。

一、創建引擎和會話

通過創建引擎、綁定引擎來創建會話,實現數據庫的訪問。

from sqlalchemy import create_engine                          # 引擎
from sqlalchemy.orm import sessionmaker                       # 創建orm的會話池,orm和sql均可以管理對象關系型數據庫,需要綁定引擎才可以使用會話,

# 創建連接
engine = create_engine("mysql+pymysql://root:1234;@127.0.0.1/test", # 需要安裝mysql和pymysql的模塊,用戶名:密碼@ip地址/某個數據庫
                       #echo=True,         # 打印操作對應的SQL語句
                       pool_size=8,       # 連接個數
                       pool_recycle=60*30 # 不使用時斷開
                       )

# 創建session
DbSession = sessionmaker(bind=engine)  # 會話工廠,與引擎綁定。
session = DbSession()                  # 實例化

session.close()  # 關閉會話

二、定義類來表示虛擬表格

在使用sqlalchemy訪問數據庫的時候,以類的形式表示表格,因此在使用之前,需要先定義類。使用類的名稱而不是tablename實現之后的增刪改查。

# 導入定義類需要的模塊
from sqlalchemy.ext.declarative import declarative_base       # 調用sqlalchemy的基類
from sqlalchemy import Column, Index, distinct, update        # 指定字段屬性,索引、唯一、DML
from sqlalchemy.types import *                                # 所有字段類型

1. 直接建立一個可調用的表格

需要先繼承基類,在定義__init__函數,設置輸入參數。

# 創建庫表類型
Base = declarative_base()  # 調用sqlalchemy的基類

class Users(Base):
    '''繼承基類'''
    __tablename__ = "users"                     # 數據表的名字
    __table_args__ = {'extend_existing': True}  # 當數據庫中已經有該表時,或內存中已聲明該表,可以用此語句重新覆蓋聲明。
    id = Column(Integer, primary_key=True)
    name = Column(String(64), unique=True)
    #email = Column(String(64))

    def __init__(self, name, email):
        self.name = name
        self.email = email                      # 聲明需要調用的特征,可以只聲明數據庫中表格列的子集
        
Base.metadata.create_all(engine)                # 表生效:將所有定義的類,使用引擎創建,此時可以在數據庫中看到這些表。

2. 創建多個相同列屬性的表格 先建立一個表格的父類,指定列的屬性,再通過繼承父類

不同的表

# 創建庫表類型
Base = declarative_base()  # 調用sqlalchemy的基類

class model_data(BASE):  
    '''創建數據庫表類:模型所需的基本字段'''
    __abstract__ = True                         # 輔助sqlAlchemy實現類的繼承,自動繼承屬性,省去super()
    __table_args__ = {'extend_existing': True}  # 若表的聲明在內存中已存在,則重新聲明表的名稱,不然會報錯
    ai_xdr_id = Column(BigInteger(), primary_key=True, unique=True, autoincrement= True)
    ai_sdk_id = Column(BigInteger())

class TrainData(model_data): # 訓練集表
    '''繼承model_data的屬性,并將表的名字定義為:'xxx_train_data'存入數據庫 '''
    __tablename__ = 'xxx_train_data'
    
class DevData(model_data):   # 開發集表
    '''表的名字定義為:'xxx_dev_data' '''
    __tablename__ = 'xxx_dev_data'

class TestData(model_data):  # 測試集表
    __tablename__ = 'xxx_test_data'

Base.metadata.create_all(engine)                # 表生效:將所有定義的類,使用引擎創建,此時可以在數據庫中看到這些表。

三、增刪改查

因為是會話操作,當某個語句,例如增加數據時,不成功的時候需要回滾。

增加數據

# 增加數據
add_user = Users("test3", "test123@qq.com")
session.add(add_user)
session.commit()

# add_users = Users(("test", "test123@qq.com"),('a','b')))
# session.add(add_users)
# session.commit()

# 當上述語句出現執行錯誤時,需要執行回滾語句,才能繼續操作
session.rollback()

刪除數據

delete_users = session.query(Users).filter(Users.name == "test").first()
if delete_users:
    session.delete(delete_users)
    session.commit()
    
session.query(Users).filter(Users.name == "test").delete()
session.commit()

更改數據

# 改
session.query(Users).filter_by(id=1).update({'name': "Jack"})

users = session.query(Users).filter_by(name="Jack").first()
users.name = "test"

查找數據

users = session.query(Users).filter_by(id=5).all()
for item in users:
    print(item.name)
    print(item.email)   # 若未在類中聲明,則無法訪問數據庫中該表的屬性。

四、進階技能

1. 將DataFrame格式的數據導入數據庫

class DataAccessLayer:# 數據連接層、定義了連接和關閉。
    '''數據連接層、定義了連接和關閉。'''
    def __init__(self):
        self.ENGINE = None                 # 引擎
        self.SESSION = None                # 會話
        self.conn_string = "mysql+pymysql://root:1234;@127.0.0.1/test"  ## 需要安裝mysql和pymysql的模塊,用戶名:密碼@ip地址/某個數據庫

    def connect(self):
        '''連接時建立引擎和會話。'''
        self.ENGINE = create_engine(self.conn_string, encoding='utf-8',isolation_level="AUTOCOMMIT", connect_args={'connect_timeout': 7200})
        # self.ENGINE = create_engine(self.conn_string, encoding='utf-8',connect_args={'connect_timeout': 7200})
        self.SESSION = sessionmaker(bind=self.ENGINE)()

    def disconnect(self):
        '''斷開時,關閉引擎。'''
        self.ENGINE.close()

def df_save_db(df,tablename):
    '''將數據集DataFrame保存到數據庫'''
    db_ac = DataAccessLayer()
    db_ac.connect()
    conn = db_ac.ENGINE.connect()
    df.to_sql(name=tablename, con=conn, if_exists='append', index=False)
    conn.close()
    print('%s updated.'%tablename)

df = pd.read_csv('traindata_jiangsu_donghai.csv')
df_save_db(df,'traindata_jiangsu_donghai')

到此這篇關于python實現sqlalchemy的使用的文章就介紹到這了,更多相關python sqlalchemy使用內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python數據庫如何連接SQLite詳解
  • Python流行ORM框架sqlalchemy的簡單使用
  • python中的mysql數據庫LIKE操作符詳解
  • Python3 MySQL 數據庫連接的使用示例
  • python配置mssql連接的方法
  • python 操作sqlite數據庫的方法
  • 適合Python項目的五大SQL連接器

標簽:普洱 林芝 寧夏 大同 海南 盤錦 南平 漯河

巨人網絡通訊聲明:本文標題《python實現sqlalchemy的使用概述》,本文關鍵詞  python,實現,sqlalchemy,的,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現sqlalchemy的使用概述》相關的同類信息!
  • 本頁收集關于python實現sqlalchemy的使用概述的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产喷白浆一区二区三区| 久久国产精品无码网站| 久久一留热品黄| 久久久久久一级片| 久久精品欧美一区二区三区不卡| 欧美老肥妇做.爰bbww视频| 欧美在线三级电影| 日韩欧美一区二区在线视频| 欧美亚洲一区三区| 日韩欧美国产麻豆| 国产精品美女久久久久aⅴ国产馆| 国产精品灌醉下药二区| 亚洲夂夂婷婷色拍ww47| 成人a免费在线看| 不卡欧美aaaaa| 日韩午夜三级在线| 国产精品区一区二区三区| 亚洲国产婷婷综合在线精品| 国产自产2019最新不卡| 欧美日产在线观看| 中文字幕中文乱码欧美一区二区 | 国产欧美日韩一区二区三区在线观看| 国产精品午夜电影| 久久 天天综合| 欧美一区二区国产| 性做久久久久久免费观看欧美| 99久久久精品| 亚洲尤物在线视频观看| 91麻豆自制传媒国产之光| 中文在线一区二区| 99精品热视频| 成人免费在线视频观看| 丁香啪啪综合成人亚洲小说 | 成人高清视频免费观看| 国产精品久久久久影院| av资源站一区| 五月天激情小说综合| 日韩一区二区免费在线电影| 美女mm1313爽爽久久久蜜臀| 国产婷婷一区二区| 91老师片黄在线观看| 麻豆成人综合网| 日韩美女在线视频| 成人av免费观看| 国产精品久久久久久福利一牛影视 | 日韩一区二区视频| 久久久久久一级片| 午夜精品久久久久久久99樱桃| 久久精品国产亚洲aⅴ| 欧美日韩国产小视频在线观看| 91黄色免费观看| 丝袜亚洲精品中文字幕一区| 国产一区二区三区黄视频 | 99re热视频这里只精品| 欧美国产精品一区二区三区| 国产成人av电影免费在线观看| 日韩亚洲电影在线| 蜜臀av一区二区| 一区在线观看视频| 欧美一区二区三区在线| 欧美中文字幕不卡| 日韩高清欧美激情| 天堂av在线一区| 国产精品区一区二区三| 欧美一区欧美二区| 在线观看视频一区二区 | 视频一区中文字幕国产| 欧美无砖专区一中文字| 欧美精品一区二区久久久| 精品亚洲porn| 国产福利91精品一区二区三区| 精品国产a毛片| 欧美一级生活片| 欧美中文字幕一区二区三区| 成人精品免费网站| 精品一区二区三区影院在线午夜 | 欧美xxx久久| 91精品久久久久久久91蜜桃| 91蝌蚪porny| 一本色道久久综合精品竹菊| 在线一区二区观看| 成人av免费在线观看| 97精品电影院| 激情小说欧美图片| 久久精品国产久精国产| 国产精品沙发午睡系列990531| 久久―日本道色综合久久| 国产欧美一区二区三区网站| 国产午夜精品久久久久久免费视| 国产性色一区二区| 亚洲欧洲美洲综合色网| 亚洲日本护士毛茸茸| 日韩精品中午字幕| 国产欧美一区二区精品性色超碰 | 国产精品国产三级国产普通话蜜臀 | 精久久久久久久久久久| 成人免费观看男女羞羞视频| 欧美做爰猛烈大尺度电影无法无天| 国产传媒欧美日韩成人| 在线观看成人免费视频| 精品久久久久一区二区国产| 国产精品三级视频| 亚洲免费伊人电影| 韩国三级中文字幕hd久久精品| av亚洲精华国产精华精| 日韩欧美激情一区| 香蕉成人啪国产精品视频综合网| 精品一区二区在线观看| 在线免费观看日本一区| 久久新电视剧免费观看| 日韩二区三区四区| 色婷婷国产精品综合在线观看| 在线观看成人小视频| 亚洲视频综合在线| 粉嫩一区二区三区在线看| 欧美岛国在线观看| 日本三级亚洲精品| 成人网在线免费视频| 国产精品乱码人人做人人爱| 久久国产人妖系列| 国产偷v国产偷v亚洲高清 | 日本女优在线视频一区二区| 欧美猛男超大videosgay| 夜夜揉揉日日人人青青一国产精品| 97久久精品人人做人人爽| 亚洲免费在线电影| 福利视频网站一区二区三区| 国产精品拍天天在线| 一本一道久久a久久精品综合蜜臀| 国产精品成人一区二区三区夜夜夜 | 久久99精品国产.久久久久久| 日韩三级伦理片妻子的秘密按摩| 国产综合色精品一区二区三区| 91精品国产综合久久久久久久 | 紧缚奴在线一区二区三区| 欧美一区二区久久久| 国产成人免费9x9x人网站视频| 日韩欧美一区在线| www.欧美日韩国产在线| 日本成人超碰在线观看| 欧美国产精品久久| 日韩一区二区电影| 91免费在线看| 高潮精品一区videoshd| 亚洲一区成人在线| 国产清纯在线一区二区www| 欧美精品电影在线播放| 91麻豆6部合集magnet| 国产一区在线不卡| 免费精品99久久国产综合精品| 中文字幕一区二区三区在线播放| 91精品国产欧美一区二区18| 色婷婷久久一区二区三区麻豆| 久久99精品久久久久久| 美女免费视频一区| 麻豆精品国产传媒mv男同| 亚洲 欧美综合在线网络| 亚洲欧美在线aaa| 国产精品福利影院| 亚洲人成网站精品片在线观看| 欧美色中文字幕| 欧美日韩和欧美的一区二区| 欧美天堂一区二区三区| 欧美日韩电影在线播放| 91.com视频| 久久久久免费观看| 精品国产精品一区二区夜夜嗨 | 偷拍一区二区三区四区| 日本亚洲天堂网| 顶级嫩模精品视频在线看| 97se亚洲国产综合自在线观| 欧美性猛片xxxx免费看久爱| 欧美美女直播网站| 国产拍揄自揄精品视频麻豆| 亚洲欧洲av一区二区三区久久| 欧美激情中文字幕一区二区| 艳妇臀荡乳欲伦亚洲一区| 国产一区二区免费看| 韩国毛片一区二区三区| 欧美午夜视频网站| 久久日一线二线三线suv| 亚洲摸摸操操av| 国产99精品国产| 久久综合九色综合久久久精品综合| 国产精品电影院| 国产91丝袜在线播放九色| 欧美日韩精品一区二区三区| 久久久久久久综合日本| 九一九一国产精品| 国产亚洲精久久久久久| 成人在线视频首页| 亚洲一区二区三区激情| 91精品国产色综合久久久蜜香臀| 日韩精品色哟哟| 欧美videos大乳护士334| 国产精品99久久久久久久vr | 成人免费视频播放| 亚洲女同ⅹxx女同tv| 日韩写真欧美这视频| 懂色av一区二区夜夜嗨|