python – 安装odbc驱动程序到azure应用程序服务

我在Azure应用服务中运行一个简单的Python Web应用程序,需要访问Azure SQL数据库.为了从python中查找Azure SQL数据库,需要安装ODBC驱动程序.我已经在我的本地机器上完成了它并且它完美地工作.
如何在运行我的应用程序的Azure计算机上安装ODBC驱动程序,或者根本不需要它?

解决方法:

根据我的经验,Azure Web App Service Runtime是Windows系统.这不需要重装驱动程序.

我试图在我的烧瓶网络应用程序中访问Azure SQL数据库.

你可以参考我的工作代码.

view.py

from datetime import datetime
from flask import render_template
from jaygongflask import app
import pyodbc

@app.route('/database')
def database():
    """Renders the about page."""
    cnxn = pyodbc.connect('DRIVER={ODBC Driver 13 for SQL Server};SERVER=***.database.windows.net;DATABASE=***;UID=***;PWD=***')
    cursor = cnxn.cursor()
    cursor.execute("select * from dbo.Student")
    row = cursor.fetchall()
    #for r in row:
     #   print r
    return render_template(
        'database.html',
        title='Database',
        year=datetime.now().year,
        message='Database query result.',
        queryResult = row
    )

安装pyodbc包

在这里,我使用python361x64扩展.所以我在KUDU中运行命令python -m pip install pyodbc.

python  – 安装odbc驱动程序到azure应用程序服务

获取查询结果

访问网址http://***.azurewebsites.net/database.

python  – 安装odbc驱动程序到azure应用程序服务

希望它可以帮助你.任何关注,请让我知道.

更新答案:

web.config中:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <appSettings>
    <add key="WSGI_HANDLER" value="jaygongflask.app"/>
    <add key="PYTHONPATH" value="D:\home\site\wwwroot"/>
    <add key="WSGI_LOG" value="D:\home\LogFiles\wfastcgi.log"/>
  </appSettings>
  <system.webServer>
    <handlers>
      <add name="PythonHandler" path="*" verb="*" modules="FastCgiModule" scriptProcessor="D:\home\Python361x64\python.exe|D:\home\Python361x64\wfastcgi.py" resourceType="Unspecified" requireAccess="Script"/>
    </handlers>
  </system.webServer>
</configuration>

更新答案2:

我的网络应用程序使用python361x64扩展.请参考我的步骤如下:

第1步:创建azure Web应用程序并添加扩展(这里是Python 3.6.1 x64)

python  – 安装odbc驱动程序到azure应用程序服务

第2步:发布您的烧瓶项目并添加web.config.

web.config中:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <appSettings>
    <add key="WSGI_HANDLER" value="<Your Project Name>.app"/>
    <add key="PYTHONPATH" value="D:\home\site\wwwroot"/>
    <add key="WSGI_LOG" value="D:\home\LogFiles\wfastcgi.log"/>
  </appSettings>
  <system.webServer>
    <handlers>
      <add name="PythonHandler" path="*" verb="*" modules="FastCgiModule" scriptProcessor="D:\home\Python361x64\python.exe|D:\home\Python361x64\wfastcgi.py" resourceType="Unspecified" requireAccess="Script"/>
    </handlers>
  </system.webServer>
</configuration>

步骤3:切换到Kudu CMD并命令cd Python361x64并触摸get-pip.py并通过编辑将url https://bootstrap.pypa.io/get-pip.py的内容复制到get-pip.py中按钮,然后运行python get-pip.py来安装pip工具.

python  – 安装odbc驱动程序到azure应用程序服务

第4步:通过python -m pip install pyodbc安装pyodbc软件包或任何你需要的软件包

python  – 安装odbc驱动程序到azure应用程序服务

更多部署详情,请参阅此tutorial.

上一篇:java – JDBC-ODBC Bridge查询到Access时,它们具有重音字符


下一篇:python – 在SQLAlchemy中,我可以从现有的ODBC连接创建引擎吗?