会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132464个问题
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 5266楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body{
            background-color: #f1f1f1;
        }
        .phone{
            width:1300px;
            height:680px;
            margin:0 auto;
        }
        .left{
            float:left;
            width:234px;
            height:680;
            margin-top:10px;
        }
        .right{
            float:right;
            width:1050px
        }
        .box{
            width:250px;
            height:300px;
            float:left;
            margin-left:10px;
            background-color:#fff;
            margin-top:10px;
            text-align:center;
        }
    </style>
</head>
<body>
    <div class="phone">
        <div class="left">
            
        <div class="right">
            <div class="box">
                <img src="//cdn.cnbj1.fds.api.mi-img.com/mi-mall/d91bb6cf7da0947e8a6e50e03f4daf06.jpg?thumb=1&amp;w=351&amp;h=921&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Xiaomi 13 限量定制色" src="//cdn.cnbj1.fds.api.mi-img.com/nr-pub/202211292351_92aba2c69123166a74ba2e2b525b1ae2.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Redmi K60" src="//cdn.cnbj1.fds.api.mi-img.com/mi-mall/a6cec580260ceb20ae6a885c2c65c611.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Xiaomi 13 Pro" src="//cdn.cnbj1.fds.api.mi-img.com/mi-mall/aa047170a22d9f0852254aa36df5f5f0.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Redmi K60 Pro" src="//cdn.cnbj1.fds.api.mi-img.com/mi-mall/f37dd30477e7ba040c7fb69c31ad8bf3.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Xiaomi 13" src="//cdn.cnbj1.fds.api.mi-img.com/mi-mall/94c6497b70f2e881460cb232082a0da6.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Redmi Note 12 Pro 极速版"  src="//cdn.cnbj1.fds.api.mi-img.com/nr-pub/202212251443_29b17941a7365948446bd193011d9241.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
            <div class="box">
                <img width="160" height="160" alt="Redmi Note 12 5G"  src="//cdn.cnbj1.fds.api.mi-img.com/nr-pub/202210262033_ef39fca0e37395d07682124770fd3ad9.png?thumb=1&amp;w=300&amp;h=300&amp;f=webp&amp;q=90" lazy="loaded">
            </div>           
        </div>
    </div>
</body>
</html>
  
  
  //不知道为什么运行的时候就出问题了,我写的是图片的网络地址

WEB前端全系列/第一阶段:HTML5+CSS3模块/初识CSS 5267楼
Python 全系列/第五阶段:数据库编程/项目-音乐播放器-旧 5268楼
Python 全系列/第五阶段:数据库编程/项目-音乐播放器-旧 5269楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器 5271楼

image.png

Python 全系列/第十一阶段:重量级Web框架-Django/Redis的入门与应用(拓展) 5272楼
JAVA 全系列/第二十阶段:租房网(Spring Cloud最新架构)/租房网 5273楼

老师,我的代码报这个错误,我直接跑老师提供的代码也是报同样错误。然后我尝试根据这个网址上的博客解决(解决flask报错:RuntimeError: Working outside of application context._bianlidou的博客-CSDN博客),但是在globals.py这个文档里找不到相应函数。

"""  
数据库连接
    数据库初始化不再是通过create_engine。
    跟sqlalchemy一样,定义好数据库连接字符串DB_URI。
    将这个定义好的数据库连接字符串DB_URI,通过SQLALCHEMY_DATABASE_URI这个key名配置到app.config中。
    app.config["SQLALCHEMY_DATABASE_URI"] = DB_URI
    使用flask_sqlalchemy.SQLAlchemy这个类定义一个对象,并将app传入进去。
    db = SQLAlchemy(app)
创建ORM模型类
    使用db.Model来作为基类
    在模型类中,Column、String、Integer以及relationship等,都不需要导入了,直接使用db下面相应的属性名就可以了
    在定义模型的时候,可以不写__tablename__,那么flask_sqlalchemy会默认使用当前的模型的名字转换成小写来作为表的名字
将ORM模型映射到数据库表
    1. 删除数据库表:db.drop_all()
    2. 创建数据库表:db.create_all()
session的使用
    直接使用db.session
查询数据
    单表查询:不再是之前的session.query方法了,而是将query属性放在了db.Model上
    多表查询:如果查找数据涉及多个模型,只能使用db.session.query(模型名).all() 这种方式
"""

from flask import Flask
from flask_sqlalchemy import SQLAlchemy

from flask import current_app


app = Flask(__name__)

# 数据库的变量
HOST = 'localhost'
PORT = 3306
DATA_BASE = 'flask_db'
USER = 'root'
PWD = '123456'
# 定义好数据库连接字符串DB_URI
DB_URI = f'mysql+pymysql://{USER}:{PWD}@{HOST}:{PORT}/{DATA_BASE}'
# 将这个定义好的数据库连接字符串DB_URI,通过SQLALCHEMY_DATABASE_URI这个key名配置到app.config中。
app.config['SQLALCHEMY_DATABASE_URI'] = DB_URI
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False

# 链接数据库  将app传入类对象
db = SQLAlchemy(app)

# 创建模型类
class User(db.Model):
    __tablename__ = 't_user'
    id = db.Column(db.Integer,primary_key = True,autoincrement = True)
    name = db.Column(db.String(32))

    def __repr__(self):
        return f'<User id={self.id} name={self.name}>'
   

class News(db.Model):
    __tablename__ = 't_news'
    id = db.Column(db.Integer,primary_key = True,autoincrement = True)
    content = db.Column(db.String(100))
    uid = db.Column(db.Integer,db.ForeignKey('t_user.id'))

    user = db.relationship('User',backref = 'newss')

    def __repr__(self):
        return f'<News id={self.id}  content={self.content}>'


 # 删除表
db.drop_all()
# 创建表
db.create_all()

# 增加数据
def create_data():
    user = User(name = '百战')
    news = News(content = 'Python内容')
    user.newss.append(news)
    db.session.add(user)
    db.session.commit()


# 查询单表数据
def query_data_one():
    users = User.query.all()
    print(users)


# 查询多表数据
def query_data_many():
    rs = db.session.query(User,News.content).join(News,News.uid == User.id).all()
    print(rs)


# 修改数据
def update_data():
    user = User.query.first()
    user.name = '百战程序员'
    db.session.commit()


# 删除数据
def delete_data():
    news = News.query.first()
    db.session.delete(news)
    db.session.commit()


if __name__ == '__main__':
    create_data()
    # query_data_one()
    # query_data_many()
    # update_data()
    # delete_data()
    # pass

image.png



Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 5274楼
JAVA 全系列/第三阶段:数据库编程/MySQL数据库的使用 5275楼
JAVA 全系列/第三阶段:数据库编程/MySQL数据库的使用 5276楼
Python 全系列/第一阶段:Python入门/面向对象 5277楼
Python 全系列/第十一阶段:重量级Web框架-Django/Redis的入门与应用(拓展) 5278楼

2023-04-13.png2023-04-13.png

WEB前端全系列/第六阶段:音乐社区高级项目模块/音乐社区项目_蓝莓派 5279楼
Python 全系列/第五阶段:数据库编程/python操作mysql 5280楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637