Flask查询以及分页

本文以Flask为例,探讨如何进行数据库查询和实现分页功能。介绍Flask的路由、视图函数与Django的异同,以及Flask内置对象如request、session、g和config的使用。同时讲解了Flask中模型的save方法,以及利用offset和limit进行分页,并结合pagination库和Bootstrap展示美观的分页效果。最后提到了抽象模型的概念及其在数据库表映射中的应用。
摘要由CSDN通过智能技术生成

Flask查询以及分页

以动物类做例子
下面创建动物的表

class Animal(db.Model):
    id = db.Column(db.INTEGER, primary_key=True, autoincrement=True)
    a_name = db.Column(db.String(32))
    a_age = db.Column(db.Integer, default=1)

    def save(self):
        db.session.add(self)
        db.session.commit()

下面定义了一个save方法
使我们在定义完对象之后,可以直接调用save方法去存储对象
django中存储对象的时候就是对象.save(),这里就是把flask中添加对象并且提交封装成了save()函数,使我们去调用save函数从而添加并且提交对象

路由:

@app.route('/add_animal/')

flask中路由跟django中的路由有一点不同,flask中路由以装饰器的形式直接写在视图函数上面,而django是从urls文件中单独去写路由,各有利弊。前者比较直观在那个视图函数上方就是那个的路由,不容易搞混,因为可能一个app路由有很多个,但是不利于查找,反而第二种方法,把路由统一存在一个urls文件中,这样方便管理,查找起来也不是很麻烦。

视图函数:

def add_animal():
    name = request.args.get("name")
    age = request.args.get("age")
    animal = Animal()
    animal.a_name = name
    animal.a_age = age
    animal.save()
    return "动物添加成功"

flask中的视图函数跟django中的视图函数没什么不同。不同的点就是django中request.GET.get(),这里就是request.args.get()。

下面是查询:

animals = Animal.query.all()
animals = Animal.query.filter(Animal.a_age <= 3)
animals = Animal.query.filter(Animal.a_age.__le__(3))
animals = Animal.query.filter(Animal.a_name.contains("小"))
animals = Animal.query.filter(Animal.a_age.in_([1,2,3,4,5,
以下是一个基于 Nodejs、Express 和 EJS 的分页查询实现示例: 首先,安装必要的依赖: ``` npm install express ejs mongoose express-flash express-session ``` 然后,创建一个名为 `app.js` 的文件,引入所需模块: ```javascript const express = require('express'); const mongoose = require('mongoose'); const session = require('express-session'); const flash = require('express-flash'); const bodyParser = require('body-parser'); const app = express(); const port = process.env.PORT || 3000; // 连接 MongoDB 数据库 mongoose.connect('mongodb://localhost:27017/test', {useNewUrlParser: true, useUnifiedTopology: true}); // 定义数据库模型 const Article = mongoose.model('Article', { title: String, content: String, created_at: Date }); // 设置模板引擎和静态文件目录 app.set('view engine', 'ejs'); app.use(express.static(__dirname + '/public')); // 设置 session 和 flash app.use(session({ secret: 'mysecretkey', resave: true, saveUninitialized: true })); app.use(flash()); // 设置 bodyParser app.use(bodyParser.urlencoded({ extended: true })); // 定义路由 app.get('/', async function(req, res) { const perPage = 5; const page = req.query.page || 1; const articles = await Article.find() .skip((perPage * page) - perPage) .limit(perPage); const count = await Article.countDocuments(); const totalPages = Math.ceil(count / perPage); res.render('index', { articles: articles, current: page, pages: totalPages }); }); app.listen(port, function() { console.log('Server listening on port ' + port); }); ``` 在 `views` 文件夹中创建一个名为 `index.ejs` 的文件,用于显示分页数据: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>分页查询</title> </head> <body> <h1>文章列表</h1> <% if (articles.length > 0) { %> <ul> <% articles.forEach(function(article) { %> <li><%= article.title %></li> <% }); %> </ul> <% } else { %> <p>没有文章。</p> <% } %> <% if (pages > 1) { %> <div class="pagination"> <ul> <% if (current == 1) { %> <li class="disabled"><span>«</span></li> <% } else { %> <li><a href="?page=<%= current - 1 %>">«</a></li> <% } %> <% for (var i = 1; i <= pages; i++) { %> <% if (i == current) { %> <li class="active"><span><%= i %></span></li> <% } else { %> <li><a href="?page=<%= i %>"><%= i %></a></li> <% } %> <% } %> <% if (current == pages) { %> <li class="disabled"><span>»</span></li> <% } else { %> <li><a href="?page=<%= current + 1 %>">»</a></li> <% } %> </ul> </div> <% } %> </body> </html> ``` 在上面的示例中,我们使用了 `mongoose` 连接 MongoDB 数据库,并定义了一个名为 `Article` 的数据库模型。在路由中,我们使用 `await` 关键字来等待查询结果,并通过 `skip()` 和 `limit()` 方法来实现分页查询。在视图中,我们使用 EJS 模板引擎来生成分页链接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值