[使用Flask,python根据用户输入自动生成SQL脚本

问题描述 投票:0回答:2

问题:我们正在运行一个arduous更新脚本。由于安全性问题,更新需要大量时间。我们要确保我们正确/想要编辑更新脚本,以避免所有权限问题。

解决方案:使用Flask作为前端GUI,可以消除添加错误值的可能性。 Flask应用程序将通过自动生成脚本来确保将输入正确放置在更新脚本中,因此我们只需将其复制并粘贴到SSMS中即可。


我当前遇到的问题是美学。我能够使用用户输入生成flask应用程序并导出SQL脚本。问题是,SQL看起来很可怕,这是输出示例:enter image description here


理想情况下,输出将是多行的,就像所有当前的SQL脚本一样:

UPDATE table_name
SET ordercomplete = 1
WHERE UserName = 'testuser' and OrderID = 12345

下面是我的文件:


#templates  home.html
<!doctype html>

<head>

    <meta name="viewport" content="width=device-width, initial-scale=1">

    <title>SQL Auto Generate</title>


    <link rel="stylesheet" href="https://unpkg.com/[email protected]/build/pure-min.css" integrity="sha384-UQiGfs9ICog+LwheBSRCt1o5cbyKIHbwjWscjemyBMT9YCUMZffs6UqUTd0hObXD" crossorigin="anonymous">

    <link rel="stylesheet" type="text/css" href="{{ url_for('static', filename='style.css') }}">

</head>

<h1>SQL Auto Generate</h1>

<h2>Add the following inputs, select 'Submit' to generate a script for SQL</h2>
<body>

<div class="main">
    <form class="pure-form" method="POST" action="/">
    UserName:<br>
    <input type="text" name="UserName"><br>
    OrderID:<br>
    <input type="number" name="OrderID"><br>
    <button type="submit" class="pure-button pure-button-primary" value="Submit">Submit</button>
    </form>
</div>

<br>

<div class="main">
    {% if UserName %}
        <p>
        {% print('''
        UPDATE table_name
          SET ordercomplete = 1
        WHERE
          UserName = {} and OrderID = {}
      '''.format(UserName, OrderID)) %}
        </p>
    {% endif %}
</div>

</body>

# app.py

from flask import Flask, render_template, request

app = Flask(__name__)

@app.route('/', methods=['GET', 'POST'])
def index():
    UserName = ''
    OrderID = ''
    if request.method == 'POST' and 'UserName' in request.form:
        UserName = request.form.get('UserName')
        OrderID = int(request.form.get('OrderID'))

    return render_template("home.html", UserName=UserName, OrderID = OrderID)

if __name__ == '__main__':
    app.run(debug=True)


我也上传到github:https://github.com/jpf5046/sqlflask

Ask:是否有更好的方法通过flask创建多行文本输出?

python sql flask auto-generate
2个回答
1
投票

默认情况下,HTML会忽略多余的空间,例如行尾。如果要完全像生成查询一样显示查询,请使用<pre>

<pre>

0
投票

我认为您只需要在HTML中添加<pre> UPDATE table_name SET ordercomplete = 1 WHERE UserName = {{UserName}} and OrderID = {{OrderId}} </pre> 标签

br

© www.soinside.com 2019 - 2024. All rights reserved.