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