留言板(python+flask+sql server)保存在数据库

目录

数据库留言表的创建

留言板表单的实现

跳转到留言页面

接收表单数据,并入数据库

留言数据的删除

效果展示:

留言表单页

留言页面

留言成功


学习内容简单实现:flask框架+前端展示网页效果,python通过pymssql模块操作SQL server ,最终实现留言功能。其留言数据存储在sql server表中


  • 数据库留言表的创建

  • 列名:id编号  昵称  留言信息  留言时间

代码:  --identity(1, 1) 起始值1,自增量1,且设置id为主键

create table liuyan
(
id int  identity(1, 1)  not null primary key, --identity(1, 1) 起始值1,自增量1,且设置ID为主键
name nvarchar(30) not null,
info nvarchar(50) not null,
date datetime not null default getdate()
)
 

效果:

import pymssql
from flask import Flask, render_template, request

app = Flask(__name__)


@app.route('/')
def index():
    sql2 = 'select * from liuyan'
    data = sql(sql2)

    print(data)

    return render_template('table.html', data=data)


def sql(sql2):
    connect = pymssql.connect(server='LAPTOP-DUHL1TTU\YXHLHM',  # 服务器名或本地IP
                              user='sa',  # 账户
                              password='*****',  # 自己设置的密码
                              database='yxh2',
                              as_dict=True)  # 数据库内容以字典格式输出
    if connect:
        print("恭喜你,连接成功 !!!")
    cur = connect.cursor()  # 创建游标对象
    connect.commit()  # 提交数据
    cur.execute(sql2)  # 执行sql语句

    data = cur.fetchall()  # 查看sql语句执行的结果

    connect.close()  # 关闭连接
    return data


if __name__ == "__main__":
    app.run(debug=True)
  • table.html文件
<!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>表单</title>
    <style type="text/css">
        table {
            width: 600px;
            height: 100px;
            text-align: center;
        }

        caption {
            padding-bottom: 20px;
            font-size: 46px;
            color: white;
            text-shadow: 1px 1px 2px black,
                0 0 25px blue,
                0 0 5px darkblue;
        }
    </style>
</head>

<body>
    <center>
        <table border="1">
            <caption>留言板</caption>
            <tr>
                <th>id编号</th>
                <th>昵称</th>
                <th>留言信息</th>
                <th>留言时间</th>
                <th>删除操作</th>

            </tr>
            {% for i in data %}
            <tr>
                <td>{{ i.id }}</td>
                <td>{{ i.name }}</td>
                <td>{{ i.info }}</td>
                <td>{{ i.date }}</td>
                <td><a href="/delete?id={{i.id}}">删除留言</a></td>

            </tr>
            {% endfor %}

        </table>
    </center>
    <center>
        <h3>
            <a href="/liuyan">点击发布留言</a>
        </h3>
    </center>
</body>

</html>
  • 跳转到留言页面

# 跳转添加留言页面
@app.route('/liuyan')
def liuyan():
    return render_template('liuyan.html')
  • ​​​​liuyan.html
  • <form action="/insert" method="post">,这里注意地址指向为后面的insert视图,且为post提交方式
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8" />
    <title>留言板</title>
    <style type="text/css">
        table {
            width: 350px;
            height: 350px;
            background: linear-gradient(200deg, #a1ffce, #faffd1);

        }

        caption {
            padding-bottom: 20px;
            font-size: 46px;
            color: white;
            text-shadow: 1px 1px 2px black,
                0 0 25px rgb(31, 171, 68),
                0 0 5px rgb(118, 167, 11);
        }

        .colour {
            background-color: #a1ffce;
        }
    </style>
</head>

<body>
    <center>
        <table>
            <caption>留言板</caption>
            <form action="/insert" method="post">
                <tr>
                    <td>昵称:</td>
                    <td><input type="text" name="name"></td>
                </tr>

                <tr>
                    <td>留言信息:</td>
                    <td>
                        <textarea name="info" id="" cols="30" rows="10">请输入您的留言...</textarea>
                    </td>
                </tr>
                <tr>
                    <th class="bottn">
                        <input type="submit" class="colour" value="点击留言">
                    </th>

                </tr>
            </form>
        </table>
    </center>
</body>

</html>
  • 接收表单数据,并入数据库

代码:

# 接收表单数据,并入数据库
@app.route('/insert', methods=['POST'])
def insert():
    connect = pymssql.connect(server='LAPTOP-DUHL1TTU\YXHLHM',  # 服务器名或本地IP
                              user='sa',  # 账户
                              password='123456',  # 自己设置的密码
                              database='yxh2',
                              as_dict=True)  # 数据库内容以字典格式输出
    if connect:
        print("恭喜你,连接成功 !!!")
    cur = connect.cursor()  # 创建游标对象
    # connect.commit()  # 提交数据
    # cur.execute(sql2)  # 执行sql语句

    # data = cur.fetchall()  # 查看sql语句执行的结果
    # 接收表单数据
    data = request.form.to_dict()
    # 添加时间
    data['date'] = time.strftime('%Y-%m-%d %H:%I:%S')

    # print(data['date'])
    # 数据入库 'insert into liuyan(name,info) values(%s,%s)'
    name = data["name"]
    info = data["info"]
    sql = 'insert into liuyan(name,info) values(%s,%s)'
    cur.execute(sql, (name, info))
    connect.commit()

    connect.close()
    # return data

    # 数据入库  insert into liuyan(name,info) values('华仔','学习')
    # sql2 = f'insert into liuyan(name,info) values(null,"{data["name"]}","{data["info"]}")'
    # resp = sql(sql2)
    #
    if sql:
        return '<script>alert("留言成功");location.href="/"</script>'
    else:
        return '<script>alert("留言失败啦~~");location.href="/liuyan"</script>'

在这里:接收表单的数据且格式转为字典

    # 接收表单数据
    data = request.form.to_dict()

还有:这里用的%s来占位的,execute传递类型为元组或字典!!!

    # 数据入库 'insert into liuyan(name,info) values(%s,%s)'
    name = data["name"]
    info = data["info"]
    sql = 'insert into liuyan(name,info) values(%s,%s)'
    cur.execute(sql, (name, info))
    connect.commit()

操作后的js弹窗提示:留言成功会回到首页,失败则继续回留言页面

    if sql:
        return '<script>alert("留言成功");location.href="/"</script>'
    else:
        return '<script>alert("留言失败啦~~");location.href="/liuyan"</script>'
  • 留言数据的删除

# 接收ID,数据删除
@app.route('/delete')
def delete():
    connect = pymssql.connect(server='LAPTOP-DUHL1TTU\YXHLHM',  # 服务器名或本地IP
                              user='sa',  # 账户
                              password='123456',  # 自己设置的密码
                              database='yxh2',
                              as_dict=True)  # 数据库内容以字典格式输出
    if connect:
        print("恭喜你,连接成功 !!!")
    cur = connect.cursor()  # 创建游标对象
    id = request.args.get('id')
    # sql = 'insert into liuyan(name,info) values(%s,%s)'
    sql = 'delete from liuyan where id=%s'
    cur.execute(sql, (id))
    connect.commit()

    if sql:
        return '<script>alert("留言删除成功");location.href="/"</script>'
    else:
        return '<script>alert("留言删除失败啦~~");location.href="/liuyan"</script>'

效果展示:

  • 留言表单页

  • 留言页面

  • 留言成功

 查看留言:

 数据库中:

 删除和修改数据也是一样的..........

写在最后:

虽然有很多冗余代码,但能出效果,我已经很满足啦~~~芜湖~


拜~~~

  • 13
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
### 回答1: Python是一种强大的编程语言,其应用领域广泛,包括了数据处理、数据挖掘和爬虫等方面。在这其Python的爬虫技术已经成为数据获取和处理的重要建设板块。同时,数据库是存储和管理数据的基本方式,其由于高效、安全和稳定等特性而被广泛应用在各个领域。 在Python的Web框架Flask是一种极为流行的工具,其为开发Web应用提供了很多便利,尤其适合小型和型的Web应用开发。在Flask框架,开发者可以使用Python编写各种功能,如路由、拦截器、数据验证、数据渲染等等。 在就业系统的建设过程PythonFlask可以负责Web应用的开发。爬虫技术则可以用于从多个网站获取招聘信息,并将其存储在数据库,包括职位、公司、薪资、职位要求等信息数据库技术则可以用于数据的管理和访问,包括SQL Server、MySQL、PostgreSQL等多种方式。 总而言之,PythonFlask、爬虫和数据库技术可以结合起来,为企业提供高效、准确和可靠的招聘数据,提高招聘质量和效率。 ### 回答2: Python是一门非常流行的编程语言,被广泛应用于爬虫、数据处理、Web开发等领域。在Web开发方面,Flask是一种轻量级的Web应用框架,易于上手,同时也有很好的扩展性和灵活性。 爬虫是将互联网上的数据爬取下来,并进行处理和分析的过程。Python有很多爬虫框架,比如Scrapy、Beautiful Soup等。而在爬取数据后,需要对其进行存储和管理,这时数据库就成了必不可少的一环。Python常用的数据库有MySQLSQLite、PostgreSQL等。 在就业系统,我们可以利用爬虫来获取各种招聘信息,并将其储存在数据库,方便后续查询和管理。Flask则可以搭建一个基于Web的简单就业系统,可以实现用户注册、登录、简历管理、招聘信息查看等功能。 总的来说,PythonFlask、爬虫和数据库在就业系统的应用,提高了数据的收集和管理效率,同时也提供了更加丰富、便捷的招聘信息查询和管理方式,帮助求职者和企业更好地完成匹配和招聘。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

抄代码抄错的小牛马

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值