網(wǎng)站首頁 編程語言 正文
前言:
大家好,今天我和大家來聊一下SQLALchemy
這個模塊,該模塊是Python當(dāng)中最有名的ORM框架,該框架是建立在數(shù)據(jù)庫API之上,使用關(guān)系對象映射進行數(shù)據(jù)庫的操作,簡而言之便是:將對象轉(zhuǎn)換成SQL,然后使用數(shù)據(jù)API執(zhí)行SQL并獲取執(zhí)行結(jié)果。
看到這里,相信不少的讀者可能會感覺到云里霧里,我們就通過一個簡單的案例在說明一下吧。
例如我們想要在mysql當(dāng)中新建一個表格,我們首先需要連接上數(shù)據(jù)庫,代碼如下:
:# 連接數(shù)據(jù)庫 sql_connect = 'mysql+pymysql://root:123456@localhost:3306/sql_prac?charset=utf8' engine = create_engine(sql_connect) DBSession = sessionmaker(bind=engine) # 創(chuàng)建對象的基類: BaseModel = declarative_base()
一、定義表結(jié)構(gòu)
對于新創(chuàng)建的表格,我們命名為是“User”,同時我們還需要定義表結(jié)構(gòu),
代碼如下:
#定義對象 class User(BaseModel): ? ? # 表名 ? ? __tablename__ = 'user' ? ? # 表結(jié)構(gòu),其中ID設(shè)為是主鍵,并且是自動增加的 ? ? id = Column(Integer, primary_key=True, autoincrement=True) ? ? name = Column(String(20)) ? ? age = Column(Integer)
二、創(chuàng)建以及刪除表
對于創(chuàng)建表以及刪除表的操作,代碼如下:
#創(chuàng)建映射的數(shù)據(jù)庫表 def init_db(): ? ? BaseModel.metadata.create_all(engine) #刪除映射的數(shù)據(jù)庫表 def drop_db(): ? ? BaseModel.metadata.drop_all(engine)
三、插入數(shù)據(jù)
我們可以嘗試往新建的表格當(dāng)中插入幾個值,
代碼如下:
def insert_data(name_1, age_1): ? ? # 創(chuàng)建session對象,相當(dāng)于MySQLdb里面的游標(biāo) ? ? session = DBSession() ? ? # 創(chuàng)建新User對象: ? ? new_user = User(name=name_1, age=age_1) ? ? # 添加到session: ? ? session.add(new_user) ? ? # 提交添加數(shù)據(jù)的操作 ? ? session.commit() ? ? # 關(guān)閉session ? ? session.close() ? ?? if __name__ == "__main__": ? ? insert_data(name_1="Mike", age_1=20) ? ? insert_data(name_1="John", age_1=35) ? ? .......
運行后的結(jié)果如下圖所示:
四、查詢
要是我們想要查詢表格中的數(shù)據(jù),可以這么來做
# 創(chuàng)建Session: session = DBSession() # 創(chuàng)建Query查詢,filter是where條件,最后調(diào)用one()返回唯一行,如果調(diào)用all()則返回所有行: user = session.query(User).filter(User.name == 'Tom').one() # 打印類型和對象的name屬性和age屬性: print(user.name, user.age) # 關(guān)閉Session: session.close()
要是調(diào)用的是all()
則返回所有行,因此我們需要通過for循環(huán)遍歷出來的結(jié)果然后打印,
代碼如下:
users = session.query(User).filter(User.name == 'John').all() for u in users: ? ? print(u.name, u.age)
五、更新和刪除數(shù)據(jù)
我們嘗試來更新表格中的一些數(shù)據(jù),代碼如下:
# 創(chuàng)建Session: session = DBSession() # 可以進行多條數(shù)據(jù)更新 user = session.query(User).filter(User.id == 3) user.update({User.age: 30}) # 提交數(shù)據(jù) session.commit() # 關(guān)閉Session session.close()
通過“ID”來鎖定要更新的數(shù)據(jù)的位置,然后我們通過調(diào)用update()方法將其年齡改成指定的值。與此同時我們還可以來刪除表格當(dāng)中的一些值,
代碼如下:
# 創(chuàng)建Session session = DBSession() # 刪除哪些數(shù)據(jù) user = session.query(User).filter(User.id == 5).one() session.delete(user) # 提交數(shù)據(jù) session.commit() # 關(guān)閉session session.close()
同樣我們也是通過“ID”來鎖定要刪除數(shù)據(jù)的位置,然后調(diào)用delete()
方法。
六、直接運行SQL語句
當(dāng)然我們在創(chuàng)建session
之后,我們也可以在里面直接運行SQL語句,例如我們想要查看一下總共有哪些數(shù)據(jù)庫,
代碼如下:
session = DBSession() print(session.execute('show databases').fetchall()) session.close()
或者我們是想返回表格中的所有數(shù)據(jù),代碼如下:
session = DBSession() print(session.execute('select * from user').fetchall()) session.close()
七、DataFrame到MySQL數(shù)據(jù)庫
我們同時也可以批量的將excel或者csv文件當(dāng)中的數(shù)據(jù)批量的導(dǎo)入到MySQL數(shù)據(jù)庫當(dāng)中,我們先通過Pandas讀取文件中的數(shù)據(jù),
代碼如下:
sql_connect = 'mysql+pymysql://用戶名:密碼@ip地址:端口號/數(shù)據(jù)庫名稱?charset=utf8' engine = create_engine(sql_connect) df = pd.read_excel("sqlalchemy_test1.xlsx") df.to_sql("user", engine, index=False, if_exists='append')
當(dāng)然我們也可以從數(shù)據(jù)庫的某個表格當(dāng)中來讀取數(shù)據(jù),代碼如下:
df = pd.read_sql("表格名", engine) print(df.head())
原文鏈接:https://blog.csdn.net/weixin_38037405/article/details/123964632
相關(guān)推薦
- 2023-02-18 Go?gin權(quán)限驗證實現(xiàn)過程詳解_Golang
- 2022-05-21 C++?Cmake的構(gòu)建靜態(tài)庫和動態(tài)庫詳解_C 語言
- 2022-07-27 Go?error的使用方式詳解_Golang
- 2022-11-17 C語言數(shù)據(jù)結(jié)構(gòu)不掛科指南之棧&隊列&數(shù)組詳解_C 語言
- 2022-04-11 python中pip安裝、升級以及升級固定的包_python
- 2022-12-21 PyGame實現(xiàn)初始化導(dǎo)入所有模塊方法詳解_python
- 2022-06-19 C++簡明講解類型轉(zhuǎn)換的使用與作用_C 語言
- 2022-06-28 C#操作Byte數(shù)組和十六進制進行互轉(zhuǎn)_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支