摘要:環(huán)境搭建安裝相應(yīng)的軟件包數(shù)據(jù)庫用于連接服務(wù)器的一個庫連接數(shù)據(jù)庫從中導(dǎo)入,創(chuàng)建引擎建立與數(shù)據(jù)庫的連接。使用方法定義的映射類依據(jù)一個基類,這個基類是維系類和數(shù)據(jù)表關(guān)系的目錄。應(yīng)用通常只需要有一個的實例。
SQLAlchemy
1.環(huán)境搭建安裝相應(yīng)的軟件包
1.mysql數(shù)據(jù)庫
2.pymysql用于連接MySQL服務(wù)器的一個庫
3.sqlalchemy
$ pip install pymysql $ pip install sqlalchemy2.連接數(shù)據(jù)庫
從sqlalchemy中導(dǎo)入create_engin,創(chuàng)建引擎建立與數(shù)據(jù)庫的連接。
from sqlalchemy import create_engine
準(zhǔn)備連接數(shù)據(jù)庫的數(shù)據(jù):
HOSTNAME = "127.0.0.1" # 這里填ip地址 PORT = "3306" # 端口號 mysql一般默認(rèn)為3306 DATABASE = "mydb" # 數(shù)據(jù)庫名 USERNAME = "admin" # 用戶名 PASSWORD = "rootqwe123" # 用戶登錄密碼
DB_URI的格式:
數(shù)據(jù)庫類型+數(shù)據(jù)庫驅(qū)動名稱://用戶名:密碼@機(jī)器地址:端口號/數(shù)據(jù)庫名?字符編碼
DB_URI=mysql+pymysql://
engine = create_engine(DB_URI)
我們可以嘗試著測試一下是否連接上:
print(dir(engine)),當(dāng)有打印出方法時,表示連接成功。
database_connect.py
from sqlalchemy import create_engine HOSTNAME = "127.0.0.1" # 這里填ip地址 PORT = "3306" DATABASE = "mydb" USERNAME = "admin" PASSWORD = "Root110qwe" Db_Uri = "mysql+pymysql://{}:{}@{}/{}?charset=utf8".format(USERNAME,PASSWORD,HOSTNAME,DATABASE) engine = create_engine(Db_Uri) if __name__=="__main__": print(dir(engine))3.創(chuàng)建模型 1.聲明映像
對象關(guān)系型映射,數(shù)據(jù)庫中的表與python中的類相對應(yīng),創(chuàng)建的類必須繼承自sqlalchemy中的基類。
使用Declarative方法定義的映射類依據(jù)一個基類,這個基類是維系類和數(shù)據(jù)表關(guān)系的目錄。
應(yīng)用通常只需要有一個base的實例。我們通過declarative_base()功能創(chuàng)建一個基類。
在database_connect.py文件中加入下列代碼
from sqlalchemy.ext.declarative import declarative_base Base = declarative_base(engine)2.創(chuàng)建會話
定義個session會話對象,使用 sessionmaker初始化一個類對象
from sqlalchemy.orm import sessionmaker Session = sessionmaker(engine) session = Session()3.新建模型
新建一個user模型
新建user_module.py文件
from datetime import datetime from sqlalchemy import Column,Integer,String,DateTime,Boolean from database_connect import Base,session class User(Base): __tablename__="user" id = Column(Integer,primary_key=True,autoincrement=True) username = Column(String(20),nullable=False) password = Column(String(100)) creatime = Column(DateTime,default=datetime.now) last_login = Column(DateTime) _locked = Column(Boolean,default=Falsem,nullable=False) #---將創(chuàng)建好的user類,映射到數(shù)據(jù)庫的user表中---
在start.py mian函數(shù)最后中加入這一行代碼
Base.metadata.create_all()
這就是創(chuàng)建好了一個表,我們可以在數(shù)據(jù)庫中查看一下。
4.增刪查改 1.增加數(shù)據(jù)def add_user(): #添加單個對象 #person = User(username="lethe",password="212121") #session.add(person) #在start.py中的main函數(shù)中執(zhí)行添加函數(shù) User().add_user()
#添加多個對象 #把a(bǔ)dd_user中的代碼注釋并添加下列代碼 session.add_all([User(username="banban", password="1212120"), User(username="kuku", password="32321")]) #提交才會生效,和命令行有區(qū)別 session.commit()
#先將前面的User().add_user()注釋掉 否者又會添加相同的數(shù)據(jù) def search_user(): row = session.query(User).all() # 查詢?nèi)繑?shù)據(jù) print(row) #再在start.py中的main函數(shù)后面添加 User().search_user()
#將search_user()里的內(nèi)容注釋掉 添加下列代碼 row = session.query(User).filter_by(id=1).all() # 按id查詢 print(row) row = session.query(User).filter(User.username == "banban").all() # 按字段查詢 print(row) print(row[0].locked) #查詢banban這條信息的locked信息
但其實我們可以在定義user類的時候這么去寫
@classmethod def all(cls): return session.query(cls).all() @classmethod def by_id(cls,id): return session.query(cls).filter_by(id=id).all() @classmethod def by_name(cls,name): return session.query(cls).filter_by(username=name).all() @property def locked(self): return self._locked
這樣在只需要調(diào)用類方法就行
print(User.all()) print(User.by_id(1)) print(User.by_name("lethe")) print(User.by_name("kuku"))3.更新
def update_user(): row = session.query(User).filter_by(username="lethe").update({User.password:"1010101"}) session.commit()4.刪除
def delete_user(): row = session.query(User).filter_by(username="banban")[0] #first print(row) session.delete(row) session.commit()
更新與刪除操作過程與前面類似 這里就不一一贅述了
以上就是sqlalchemy的基本知識。
設(shè)置步驟:
點(diǎn)擊view-->點(diǎn)擊Toll Windows -->點(diǎn)擊database
在在pycharm右側(cè)找到database,點(diǎn)開它
點(diǎn)+號-->Data Source--> 選擇mysql(我這里是用的mysql,其他數(shù)據(jù)庫也行)
按要求填寫對應(yīng)的項-->點(diǎn)擊Test connection 測試一下是否能成功連接(如果這個按鈕是灰色的需要先點(diǎn)擊左下角的按鈕安裝插件)
start.py
import tornado.httpserver import tornado.ioloop import tornado.options import tornado.web from user_module import User from tornado.options import define, options from database_connect import engine, session from user_module import Base define("port", default=9000, help="run port", type=int) if __name__ == "__main__": connection = engine.connect() result = connection.execute("select 1") print(Base) Base.metadata.create_all() # 建表 User().add_user() # User().search_user() # User().update_user() # User().delete_user() print(User.all()) print(User.by_id(1)) print(User.by_name("lethe")) print(User.by_name("kuku"))
database_connect.py
from sqlalchemy import create_engine HOSTNAME = "127.0.0.1" # 指的是linux的ip 因為代碼運(yùn)行在linux上 POST = "3306" # 直接在linux上連接數(shù)據(jù)庫不需要端口轉(zhuǎn)發(fā) DATABASE = "mydb_test" USERNAME = "admin" # 登錄的用戶 PASSWORD = "Root110qwe" db_url = "mysql+pymysql://{}:{}@{}:{}/{}".format( USERNAME, PASSWORD, HOSTNAME, POST, DATABASE ) # +號兩邊不能加空格 這里出現(xiàn)了點(diǎn)問題 將這個字符串重新寫過后就可以了 engine = create_engine(db_url) # 創(chuàng)建引擎 from sqlalchemy.ext.declarative import declarative_base Base = declarative_base(engine) # print(result.fetchone()) from sqlalchemy.orm import sessionmaker Session = sessionmaker(engine) session = Session()
user_module.py
from datetime import datetime from sqlalchemy import Column, Integer, String, DateTime, Boolean from database_connect import Base, session # 模塊名灰色代表還沒有被調(diào)用 class User(Base): # 繼承Base這個引擎 新建表 __tablename__ = "user" # 表名 id = Column(Integer, primary_key=True, autoincrement=True) username = Column(String(20), nullable=False) password = Column(String(50)) email = Column(String(50)) phone_number = Column(String(20)) id_card = Column(String(30)) createtime = Column(DateTime, default=datetime.now) _locked = Column(Boolean, default=False, nullable=True) @classmethod def all(cls): # 類方法 return session.query(cls).all() @classmethod def by_id(cls, id): return session.query(cls).filter_by(id=id).all() @classmethod def by_name(cls, name): return session.query(cls).filter_by(username=name).all() @property def locked(self): return self._locked def __repr__(self): return "" % ( self.id, self.username, self.password, self.email, self.phone_number, self.id_card, self.createtime, self._locked ) def add_user(self): # 添加單個對象 # person = User(username="lethe",password="212121") # session.add(person) # 添加多個對象 session.add_all([User(username="banban", password="1212120"), User(username="kuku", password="32321")]) # 提交才會生效,和命令行有區(qū)別 session.commit() def search_user(self): # row = session.query(User).all() # print(row) row = session.query(User).filter_by(id=1).all() print(row) row = session.query(User).filter(User.username == "banban").all() print(row) print(row[0].locked) def update_user(): row = session.query(User).filter_by(username="lethe").update({User.password: "1010101"}) session.commit() def delete_user(): row = session.query(User).filter_by(username="banban")[0] # first print(row) session.delete(row) session.commit()
將上面的這些程序放在同一目錄下 然后運(yùn)行start.py
再去ubuntu里面的mysql看一下這張表
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/44662.html
摘要:菜鳥教程框架中文手冊入門目標(biāo)使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學(xué)習(xí)指北 了解一下一下概念. RESTful API標(biāo)準(zhǔn)] 所有的API都遵循[RESTful API標(biāo)準(zhǔn)]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
摘要:菜鳥教程框架中文手冊入門目標(biāo)使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學(xué)習(xí)指北 了解一下一下概念. RESTful API標(biāo)準(zhǔn)] 所有的API都遵循[RESTful API標(biāo)準(zhǔn)]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
摘要:菜鳥教程框架中文手冊入門目標(biāo)使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學(xué)習(xí)指北 了解一下一下概念. RESTful API標(biāo)準(zhǔn)] 所有的API都遵循[RESTful API標(biāo)準(zhǔn)]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
閱讀 1333·2021-10-27 14:14
閱讀 3585·2021-09-29 09:34
閱讀 2488·2019-08-30 15:44
閱讀 1734·2019-08-29 17:13
閱讀 2578·2019-08-29 13:07
閱讀 880·2019-08-26 18:26
閱讀 3352·2019-08-26 13:44
閱讀 3218·2019-08-26 13:37