日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python實現sqlalchemy的使用概述

瀏覽:21日期:2022-07-29 09:16:12
目錄使用概述一、創建引擎和會話二、定義類來表示虛擬表格三、增刪改查四、進階技能

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

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

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

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

abstract # 輔助sqlAlchemy實現類的繼承,自動繼承屬性,省去super() 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 # 不使用時斷開 )# 創建sessionDbSession = sessionmaker(bind=engine) # 會話工廠,與引擎綁定。session = DbSession() # 實例化session.close() # 關閉會話二、定義類來表示虛擬表格

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

# 導入定義類需要的模塊from sqlalchemy.ext.declarative import declarative_base # 調用sqlalchemy的基類from sqlalchemy import Column, Index, distinct, update# 指定字段屬性,索引、唯一、DMLfrom 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 = nameself.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 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品永久网址| 在线一区电影| 成人黄色av| 国产免费播放一区二区| 国产剧情一区二区在线观看| 国产精品久久免费视频| 91精品尤物| 91精品美女| 欧美日韩亚洲一区| 国产欧美成人| 精品视频亚洲| 日韩在线视频精品| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 久久激情五月婷婷| 精品91福利视频| 欧美国产日韩电影| 日韩精品一区二区三区免费视频 | 国产成人精品福利| 欧美亚洲免费| 午夜亚洲福利| 国产精品资源| 久久国产视频网| 欧美精品三级在线| 国产麻豆精品| 国产精品久久久久久久久久久久久久久 | 超碰在线99| 国产福利电影在线播放| 国产精品地址| 视频在线不卡免费观看| 免费福利视频一区二区三区| а√天堂8资源在线| 久久久久久自在自线| 日韩免费高清| 亚洲精品电影| 亚洲精品字幕| 日本午夜精品一区二区三区电影| 日韩激情一二三区| 国产亚洲欧美日韩在线观看一区二区| 久久超碰99| 91精品在线观看国产| 欧美91视频| 日韩高清电影一区| 国产一区不卡| 国产综合婷婷| 国产精品a久久久久| 日韩精品dvd| 黑丝一区二区| 蜜桃精品视频| 亚洲午夜黄色| 99精品99| 欧美视频二区| 久久精品国产亚洲夜色av网站| 美女精品在线观看| 91亚洲精品在看在线观看高清| 成人国产精品| 亚洲18在线| 精品免费av| 午夜久久免费观看| 另类欧美日韩国产在线| 亚洲欧洲日本mm| 精品一区二区三区四区五区| 日韩视频不卡| 亚洲精品黄色| 成人av二区| 大香伊人久久精品一区二区 | 久久久久蜜桃| 五月亚洲婷婷 | 欧美不卡高清一区二区三区| 日韩一区二区三免费高清在线观看 | 久久国产精品久久久久久电车| 国际精品欧美精品| 欧美在线精品一区| 亚洲精品一区二区妖精| 国产一区二区三区免费在线 | 精品国产午夜肉伦伦影院| 日韩1区2区3区| 免费精品视频| 视频一区视频二区中文| 国产亚洲精品久久久久婷婷瑜伽| 欧美激情五月| 国产精品免费99久久久| 青青草精品视频| 一区二区电影| 亚洲免费资源| 亚洲a级精品| 日本天堂一区| 欧美亚洲三区| 免费一级欧美片在线观看网站| 欧美日本一区| 国产精品久久免费视频| 美女视频一区在线观看| 麻豆成人综合网| 欧美亚洲日本精品| 激情视频一区二区三区| 欧美gv在线| 午夜精品亚洲| 日韩激情一二三区| 麻豆一区二区99久久久久| 久久永久免费| 精品国产美女a久久9999| 国产一区二区三区久久久久久久久| 成人精品高清在线视频| 亚洲调教视频在线观看| 亚洲在线久久| 精品久久国产一区| 欧美综合另类| 国产欧美自拍一区| 日韩伦理在线一区| 亚洲欧美日韩高清在线| 1024精品一区二区三区| 免费日韩精品中文字幕视频在线| 少妇精品久久久一区二区| 综合日韩在线| 鲁大师精品99久久久| 九色精品91| 麻豆一区二区三| 国产韩日影视精品| 国产欧美日韩免费观看| 久久理论电影| 日本91福利区| 久久精品免费一区二区三区| 无码日韩精品一区二区免费| 日韩久久精品网| 欧美成人精品一级| 精品少妇av| 在线国产日韩| 日韩成人免费| 青青国产91久久久久久| 欧美日韩激情| 欧美国产精品| 婷婷久久免费视频| 日韩视频久久| 久久久一本精品| 国产精品日本一区二区不卡视频 | 日韩三区免费| 蜜臀久久99精品久久久久久9| 午夜久久福利| 国产激情一区| 美美哒免费高清在线观看视频一区二区 | 色老板在线视频一区二区| 欧美综合社区国产| 91大神在线观看线路一区| 亚洲毛片一区| 视频一区在线播放| 日韩视频一区| 日韩午夜精品| 亚洲成人一区| 午夜欧美精品| 国产suv精品一区二区四区视频| 日韩欧美三区| 中文一区一区三区免费在线观 | 国产精品成人a在线观看| 国产精品美女在线观看直播| 美女被久久久| 91精品国产调教在线观看| 麻豆视频在线看| 久久电影tv| 超级白嫩亚洲国产第一| 精品美女久久| 久久精品观看| 成人三级高清视频在线看| 久久av国产紧身裤| 久久亚洲人体| 日产精品一区| 91精品99| 伊人久久一区| 久久狠狠久久| 国产乱码精品一区二区三区亚洲人| 国产色噜噜噜91在线精品| 国产一区一一区高清不卡| 欧洲在线一区| 免费观看在线色综合| 欧美在线看片| 日韩欧美综合| 丝袜美腿亚洲一区| 亚洲精品在线二区| 日本麻豆一区二区三区视频| 国产视频一区二| 亚洲a在线视频| 亚洲精品无播放器在线播放| 深夜福利一区| 国产亚洲欧美日韩精品一区二区三区 | 国产精品毛片在线| 国内精品麻豆美女在线播放视频| 偷拍精品精品一区二区三区| 视频在线观看91| 久久亚洲国产精品尤物| 成人看片网站| 视频一区日韩| 精品国产黄a∨片高清在线| 日本午夜大片a在线观看| 亚洲精品护士| 国产精品久久久一区二区| 999久久久精品国产| 日韩高清二区| 久久精品播放| 欧美aa在线视频| 久久都是精品| 天堂8中文在线最新版在线| 91亚洲精品在看在线观看高清|