单个数据表的创建/删除以及增删改查

单个数据表的创建/删除以及增删改查

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from datetime import datetime

# ************************** 1. python3中MySQLdb报错解决方法 **************************
import pymysql
pymysql.install_as_MySQLdb()

# 实例化一个app对象
app = Flask(__name__)

# ************************** 2. 数据库的配置与实例化 **************************
# 对数据库操作(mysql, redis)
# 用于连接数据的数据库
# sqlite:////tmp/test.db
# mysql://username:[email protected]/db
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:[email protected]/UserTest'
# 如果设置成 True (默认情况), Flask-SQLAlchemy 将会追踪对象的修改并且发送信号。
# 这需要额外的内存, 如果不必要的可以禁用它。
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
# 实例化一个db对象
db = SQLAlchemy(app)

# ***********************3. 定义数据库模型************************************
# user ==== (id, username, password, email)
class User(db.Model):
    # 默认情况下表名为类的名称, 如果想要重新设置表名,  __tablename__=表名
    __tablename__ = "用户信息"
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(30), unique=True, index=True, nullable=False)  
    # unique=True用户名不能重复
    # nullable=False不能为空
    password = db.Column(db.String(20), nullable=False)
    email = db.Column(db.String(20), unique=True, index=True)
    # index=True创建索引, 提升查询效率
    # 设置默认值, 为当前用户的创建时间
    add_time = db.Column(db.DateTime, default=datetime.now())
    # ********************************************************************* 
    create_time1 = db.Column(db.DateTime, default=datetime.now)
    create_time2 = db.Column(db.DateTime, default=datetime.now())
    第一个插入的是期望的, 数据的插入时间, 每条数据插入时可自动根据当前时间生成
    第二条是一个固定的时间, 程序部署的时间, 所有的数据都是这个固定时间
    实际上默认值在mysql数据库没有体现, 都是sqlalchemy在插入数据时加的
    # *********************************************************************
    
if __name__ == '__main__':
    # 删除所有的表(drop)
    db.drop_all()
    # 创建所有的表(create)
    db.create_all()

    # 插入数据(insert)
    u1 = User(username="粉条", password="westos", email="[email protected]")
    u2 = User(username="粉丝", password="westos", email="[email protected]")
    db.session.add(u1)
    db.session.add(u2)
    db.session.commit()

此时数据库中内容:
单个数据表的创建/删除以及增删改查

    # 删除数据(delete)
    delete_user = User.query.filter_by(username="粉条").first()
    db.session.delete(delete_user)
    db.session.commit()

此时数据库中内容:
单个数据表的创建/删除以及增删改查

    # 更新数据(update)
    update_user = User.query.filter_by(username="粉丝").first()
    print("正在更新邮箱地址.......")
    update_user.email = '[email protected]'
    db.session.add(update_user)
    db.session.commit()

    # 查看数据(select)
    users = User.query.all()
    print(users)
    user = User.query.first()
    print(user.username)
    print(user.password)
    print(user.email)
    print(user.id)

此时数据库中内容:
单个数据表的创建/删除以及增删改查
命令栏中的内容:
单个数据表的创建/删除以及增删改查

最常用的SQL列类型

单个数据表的创建/删除以及增删改查

最常用的SQL列属性选项

单个数据表的创建/删除以及增删改查

查询过滤器总结

单个数据表的创建/删除以及增删改查

sqlalchemy执行函数总结

单个数据表的创建/删除以及增删改查