138.python内置模块sqlalchemy进行sql操作详解

文章目录

本文只针对于sqlalchemy连接mysql

sqlalchemy官方

安装

复制代码
pip3 install sqlalchemy

使用

参数解释

  1. 创建一个引擎,目的是连接到我们的数据库上
    root: mysql 用户名
    password: 密码
    host: 主机ip
    dataBaseName: 数据库名字

    create_engine('mysql+pymysql://root:password@host:3306/dataBaseName',echo=True)

  2. 打开数据库的连接会话

    session = sessionmaker(engine)

  3. 保证线程安全

    db_session = scoped_session(session)

  4. 获取基类

    Base = declarative_base()

详解demo

我的user

连接我的数据库

复制代码
import hashlib
import json
from sqlalchemy import create_engine, Column, Integer, String, Table, func
from sqlalchemy.orm import sessionmaker, scoped_session, declarative_base
from sqlalchemy import or_
from sqlalchemy.sql.elements import and_

# 创建一个引擎,目的是连接到我们的数据库上
engine = create_engine('mysql+pymysql://root:[email protected]:3306/myDataBase',echo=True)
# 打开数据库的连接会话
session = sessionmaker(engine)
# 保证线程安全
db_session = scoped_session(session)
# 获取基类
Base = declarative_base()

表链接

复制代码
class User(Base):
    __table__ = Table("user",Base.metadata,autoload_with=engine)
查询
  1. 查询所有

    result01 = db_session.query(User).all()
    print(result01)

  2. 查询判断( < > = or and like limit sum )

    result = db_session.query(User).filter(User.user_id < 10).all()

    result = db_session.query(User).filter(User.user_id > 10).all()

    result = db_session.query(User).filter(User.user_id > 10).limit(10).all()

    result = db_session.query(User).filter(User.user_id > 10).limit(10).offset(2).all()

    result = db_session.query(User).filter(or_(User.user_id == 1, User.user_id == 2)).all()

    result = db_session.query(User).filter(and(User.user_id == 1, User.username == '[email protected]')).all()

    result = db_session.query(func.sum(User.user_id)).all()

    result = db_session.query(User).order_by(User.user_id.desc()).all()

    result = db_session.query(User).order_by(User.username.like("%@qq.com")).all()

删除
复制代码
result = db_session.query(User).filter(User.user_id == 1).delete()
增加
复制代码
params = {
   "username": '"张三",
   "nickname": "zs",
   "password": 123,
   "picture": "1.png",
}
user = User(**params)
db_session.add(user)
db_session.commit()
相关推荐
GottdesKrieges2 小时前
OceanBase数据库磁盘空间管理
java·数据库·oceanbase
Themberfue3 小时前
Redis ⑦-set | Zset
java·开发语言·数据库·redis·sql·缓存
rainFFrain6 小时前
(MySQL)库的操作
数据库·mysql
八股文领域大手子8 小时前
深入理解缓存淘汰策略:LRU 与 LFU 算法详解及 Java 实现
java·数据库·算法·缓存·mybatis·哈希算法
noravinsc8 小时前
django admin 中更新表数据 之后再将数据返回管理界面
数据库·django·sqlite
春风不会绿大地8 小时前
IDEA编写flinkSQL(快速体验版本,--无需配置环境)
sql·flink
Bruce-li__10 小时前
DRF凭什么更高效?Django原生API与DRF框架开发对比解析
数据库·django·sqlite
noravinsc10 小时前
connection.cursor() 与 models.objects.filter
数据库·django·原生查询·orm查询
laimaxgg12 小时前
MySQL复合查询
数据库·mysql
编程在手天下我有12 小时前
Redis 常见问题深度剖析与全方位解决方案指南
数据库·redis·缓存·性能优化·数据持久化·分布式系统