溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python 之 sqlalchemy查詢數(shù)據(jù)

發(fā)布時間:2020-07-18 22:37:04 來源:網(wǎng)絡(luò) 閱讀:2100 作者:wx592bc92b285c7 欄目:編程語言

表結(jié)果:

Python 之 sqlalchemy查詢數(shù)據(jù)

Python 之 sqlalchemy查詢數(shù)據(jù)

查詢代碼:

#Author Kang

import sqlalchemy
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column,Integer,String
from sqlalchemy.orm import sessionmaker

#創(chuàng)建對象的基類:
Base = declarative_base()

#定義User對象:
class User(Base):
    #表的名字:
    __tablename__ = 'user'

    #表的結(jié)構(gòu):
    userid = Column(Integer,primary_key=True)
    username = Column(String(20))
    age = Column(Integer)
    department = Column(String(20))

#初始化數(shù)據(jù)庫連接
engine = create_engine("mysql+pymysql://kang:123456@10.3.152.35/test",encoding="utf-8")

#創(chuàng)建session類型
DBSession = sessionmaker(bind=engine)

#創(chuàng)建session對象
session = DBSession()

print("打印單條信息>>>>>>>>>>>>>>>>>>>>>>>>>>>>>")
#建立查詢條件,并打印第一條信息
user_info = session.query(User).first()
print(user_info.userid,user_info.username,user_info.age,user_info.department)

#print("打印所所有人員信息>>>>>>>>>>>>>>>>>>>>>>>>")
#建立查詢所有數(shù)據(jù)
#all_user = session.query(User).all()
#for i in all_user:
#   print(i.userid,i.username,i.age,i.department)

print("打印小于30歲的人員信息>>>>>>>>>>>>>>>>>>>>>")
#建立過濾條件查詢,小于30歲的人(filter的使用)
age_info = session.query(User).filter(User.age<30).all()
for i in age_info:
    print(i.userid, i.username, i.age, i.department)

print("打印部門均為IT部的人員信息>>>>>>>>>>>>>>>>>>")
#建立過濾條件查詢,部門是IT(filter_by的使用)
department_info = session.query(User).filter_by(department="IT").all()
for i in department_info:
    print(i.userid, i.username, i.age, i.department)

結(jié)果:

打印單條信息>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
3 MK 23 IT
打印小于30歲的人員信息>>>>>>>>>>>>>>>>>>>>>
3 MK 23 IT
6 CC 25 IT
8 JOHN 22 IT
15 Jack 23 FIN
打印部門均為IT部的人員信息>>>>>>>>>>>>>>>>>>
3 MK 23 IT
6 CC 25 IT
8 JOHN 22 IT

filter()和filter_by()的區(qū)別:

Filter: 可以像寫 sql 的 where 條件那樣寫 > < 等條件,但引用列名時,需要通過 類名.屬性名 的方式。
filter_by: 可以使用 python 的正常參數(shù)傳遞方法傳遞條件,指定列名時,不需要額外指定類名。,參數(shù)名對應(yīng)名類中的屬性名,但似乎不能使用 > < 等條件。
當(dāng)使用filter的時候條件之間是使用“==",fitler_by使用的是"="。
Python 之 sqlalchemy查詢數(shù)據(jù)

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI