day67-BBS

表结构设计

    项目最最重要是表结构设计
        如果一张表内的数据分成两块 一块是经常使用的 一块是不经常使用的,这个时候考虑数据优化的问题
        一对一关系
            1.一张表拆成了两张表
            2.两张表中的数据是一一对应的
        
        用户表(利用auth_user表)
            phone
            avatar
            create_time
            blog            一对一个人站点
            
                ps:DateField()
                    auto_now:每次操作数据都会将当前时间更新
                    auto_now_add:自动将创建该数据的时间记录下来之后不再改变
                
        个人站点表
            站点名称 site_name
            站点标题 site_title
            站点样式 site_theme
        
        文章表    
            文章标题 title
            文章简介 desc
            文章内容 content
            发布时间 create_time
            
            blog            一对多个人站点
            category        一对多分类表
            tag             多对多标签表
            
            # 数据库设计优化(******)
            up_num
            down_num
            comment_num 
            # 当你操作点赞点踩表或者评论表的时候 只要保证上面三个同步更新
            
            
        
        标签表
            tag_name
            blog          一对多个人站点
        
        分类表
            category_name
            blog            一对多个人站点
            
        
        点赞点踩表
            user            一对多user表
            article            一对多article表  
            is_up           0/1
        
        文章评论表
            user            一对多user表
            article         一对多article表  
            content         
            create_time
            parent          自关联评论表 (to='self')  # self表示的就是当前表
            
        
        表与表之间关系判断
            表中的一条数据能否对于另外一张表的多条数
            

            img标签的src属性可以接受三种类型的值
                1.图片的文件路径
                2.图片的二进制数据
                3.url地址
        

 

 

转载于:https://www.cnblogs.com/klw1/p/11234538.html

Day17 中,我们可以通过 Flask 框架快速搭建一个 BBS 论坛。具体步骤如下: 1. 创建 Flask 应用 ```python from flask import Flask app = Flask(__name__) ``` 2. 创建数据库 ```python from flask_sqlalchemy import SQLAlchemy app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///bbs.db' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False db = SQLAlchemy(app) ``` 3. 创建数据库模型 ```python class User(db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(20), unique=True, nullable=False) password = db.Column(db.String(20), nullable=False) class Post(db.Model): id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(100), nullable=False) content = db.Column(db.Text, nullable=False) user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False) ``` 4. 创建路由和视图函数 ```python @app.route('/') def index(): posts = Post.query.all() return render_template('index.html', posts=posts) @app.route('/post/<int:post_id>') def post(post_id): post = Post.query.get(post_id) return render_template('post.html', post=post) @app.route('/new_post', methods=['GET', 'POST']) def new_post(): if request.method == 'POST': title = request.form['title'] content = request.form['content'] user_id = 1 # 假设当前用户为 id 为 1 的用户 post = Post(title=title, content=content, user_id=user_id) db.session.add(post) db.session.commit() return redirect('/') return render_template('new_post.html') @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': username = request.form['username'] password = request.form['password'] user = User.query.filter_by(username=username, password=password).first() if user: session['user_id'] = user.id return redirect('/') else: flash('用户名或密码错误') return render_template('login.html') @app.route('/logout') def logout(): session.pop('user_id', None) return redirect('/') ``` 5. 创建 HTML 模板 创建 index.html、post.html、new_post.html、login.html 四个模板文件,并且使用 jinja2 模板引擎渲染数据。 6. 运行应用 ```python if __name__ == '__main__': app.run() ``` 以上就是快速搭建 BBS 论坛的主要步骤,当然在实际应用中还需要考虑更多细节问题,比如用户认证、数据校验、页面美化等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值