flask连接mysql数据库
A. 新手求教 python3 用 flask-sqlalchemy pymysql 连接 mysql
python3 用 flask-sqlalchemy pymysql 连接 mysql
这个问题经常难道新手一下,因为大部分教程里(包括经典的《Flask
Web开发》一书),告诉了我们如何使用flask-sqlalchemy操作sqlite,但在生产环境(线上网站)上,我们肯定是使用MySQL或其
他,而大部分的教程里,又告诉我们flask-sqlalchemy使用MySQL的方式是:
mysql://username:password@server/db
结果我们照葫芦画瓢的来一下,发现压根不行,写好的网站一跟数据库沾边就报错。
Python和MySQL是“两个国家的人”,他们互不相通,因而需要一个中间代理,让双方互通有无,跟翻译一样(这比喻不准确,但足够你明白意思就行)。翻译又有很多选择,不同的翻译各有特色。
题
主解决问题选择的翻译是“flask-mysqldb”,其背后的主子是“MySQL-python”。恩,说到这里你应该知道,“flask-xxx”
这样的包都是对背后主子进行了适合Flask封装的插件,跟包子皮一样,里面的馅才是重点,“flask-mysqldb”的馅是“MySQL-
python”。
而我要推荐的是另一个翻译:PyMySQL,这玩意的好处是可以做异步(“MySQL-python”也可以,个人口味罢了),简而言之,网站访问量大了就需要考虑异步,现在别管这是啥子。这玩意的安装方式是:
pip install PyMySQL
之后,数据库连接由:
mysql://username:password@server/db
改为
mysql+pymysql://username:password@server/db
就可以了。
B. 如何根据数据库中的经纬度在地图上显示位置 flask+mysqlmysql
电子地图标注软件可以标注位置,可以搜索地图上本来有的位置和标注的位置,可以把某个标注的位置显示在地图中心。软件有很多功能,请用户们来体验吧!
软件支持电脑在线(离线)地图查看浏览,支持无人机航拍地图导入!
1.支持谷歌在线(离线)网络地图,网络卫星地图,混合卫星地图,普通地图,地形地图,微软电子地图,微软卫星地图,bing地图,高德地图,在软件界面上可以选择地图类型切换;
2.支持1-20级的地图随意缩放,鼠标右键拖动漫游。
3.支持名称查询定位,可以输入地点名称后定位到所查询的位置。
4.支持坐标查询定位,可以输入坐标数值后定位的所查询的位置。
5.支持用户自定义信息,信息高级查询,查询结果实时定位。
6.支持在地图上所选择的标注能点击查看详细信息。
7.支持添加地图标记,距离测量显示,地点名称显示。
8.支持保存您当前操作的文件,供日后打开再用,保证操作不会丢失。
9.支持添加自定义标识图标,用户可以更换图标。
10.新增批量导入导出数据功能,网络代理设置。
11.新增分类图层管理。
12.图标上方显示文字。
13.支持在地图上绘制路线。
14.支持gps卫星定位。
15.支持商圈范围功能。
16.支持出图带标注功能。
17.支持打印出图。
18.支持行政区域边界及谷歌地球kml文件导入。
C. python flask框架怎么把A数据库中查询出的部分数据导入B数据库(mysql数据库)
fromsqlalchemyimporttext
sql=text('selectnamefrompenguins')
result=db.engine.execute(sql)
思路就是用flask执行原生sql语句
写好查询A数据库到B数据库的语句直接执行即可,效率最高
D. flask怎样查询mysql并显示在页面上
用 Flask-SQLAlchemy(SQLAlchemy ORM 模块的 Flask 定制版)。这个在定义 schema、连接数据库、增删改查方面都给你提供极大的便利。
这个对象就包含 sqlalchemy 和 sqlalchemy.orm 中的所有函数和助手。此外它还提供一个名为 Model 的类,用于作为声明模型时的 delarative 基类:
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True)
email = db.Column(db.String(120), unique=True)
def __init__(self, username, email):
self.username = username
self.email = email
def __repr__(self):
return '<User %r>' % self.username
E. 用flask连接数据库进行数据可视化时出错,请大神帮忙看看
shell连接不同的数据库会有不同的连接命令,像连oracle用sqlplus命令, mysql 用mysql命令,sybase用isql命令
如连接oracle:sqlplus 用户名/密码@ip地址[:端口]/service_name [as sysdba]
mysql命令 应该是mysql -u用户名 -p用户密码 -hIP
Access不清楚,access能安装在unix上吗?应该只能在windows上才能用吧.
F. 请教flask如何同时连接多个数据库
shell连接不同的数据库会有不同的连接命令,像连oracle用sqlplus命令, mysql 用mysql命令,sybase用isql命令
如连接oracle:sqlplus 用户名/密码@ip地址[:端口]/service_name [as sysdba]
mysql命令 应该是mysql -u用户名 -p用户密码 -hIP
Access不清楚,access能安装在unix上吗?应该只能在windows上才能用吧.
G. 如何用flask实现一个web应用来显示在mysql数据库中查询到的内容
用 Flask-SQLAlchemy(SQLAlchemy ORM 模块的 Flask 定制版)。这个在定义 schema、连接数据库、增删改查方面都提供极大的便利。
这个对象就包含 sqlalchemy 和 sqlalchemy.orm 中的所有函数和助手。此外它还提供一个名为 Model 的类,用于作为声明模型时的 delarative 基类:
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db'
db = SQLAlchemy(app)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True)
email = db.Column(db.String(120), unique=True)
def __init__(self, username, email):
self.username = username
self.email = email
def __repr__(self):
return '<User %r>' % self.username
H. 怎么用flask+mysql来实现一个简单的用户注册和登陆效果的页面
用flask+mysql实现用户的注册和登录:
一个简单的用户注册和登录的页面,就两个部分。
涉及到数据库,存储用户数据(注册),读出用户数据(登录验证)。搞清楚如何用python连接和操作数据库即可,还有了解sql数据库语句,sqlite和mysql差不多的,看几眼多试几下就了解了。
网站程序,前端如何发送表单,后端获取用户发送的请求,和数据库中数据验证是否能够登录,然后登录后如何保存用户登录信息,就是使用的cookie,不过在flask中是session(其实session也是cookie,flask把它封装了下,成了加密的cookie)。
举例如下:
(fn):
@wraps(fn)
defwrapper(*args,**kwds):
user=session.get('logged_in',None)
ifuser:
returnfn(user=user)
else:
returnredirect(url_for('signin',next=request.path))
[email protected]('/home')@authorizedefhome(**kwds):
username=kwds['user']
returnrender_template('index.html',username=username)#加密存储密码_password(password,salt=None):
ifnotsalt:
salt=os.urandom(16).encode('hex')#length32
result=password
foriinrange(3):
result=hashlib.sha256(password+salt).hexdigest()[::2]#length32
returnresult,salt#简单的错误处理classloginError(Exception):
def__init__(self,value):
self.value=value
def__str__(self):
returnrepr(self.value)#注册登录(下面的代码没有实际运行过)#连接数据库我是使用的是mysql.connector#http://dev.mysql.com/downloads/connector/python/#写法和常用的MySQL-python稍有所不同#下面没有连接数据库的代码@app.route('/register/',methods=['GET','POST'])defrequest():
ifrequest.method=='GET':
returnrender_template("register.html")
ifrequest.method=='POST':
#这里最好需要验证用户输入,我就不写了
u=request.form['username']
p,s=encrypt_password(request.form['password'])
g.db.cursor.execute('INSERTINTOusers(name,password,salt)VALUES(%s,%s,%s)',(u,p,s,)
g.db.commit()
returnredirect(url_for('signin'))@app.route('/signin/',methods=['GET','POST'])defsignin():
ifrequest.method=='GET':
referrer=request.args.get('next','/')
returnrender_template("login.html",next=referrer)
ifrequest.method=='POST':
u=request.form['username']
p=request.form['password']
n=request.form['next']
try:
g.db.cursor.execute('SELECT`name`FROMusersWHEREname=%s',(u,))
ifnotg.db.cursor.fetchone():
raiseloginError(u'错误的用户名或者密码!')
g.db.cursor.execute('SELECT`salt`,`password`FROMusersWHEREname=%s',(u,))
salt,password=g.db.cursor.fetchone()
ifencrypt_password(p,salt)[0]==password:
session['logged_in']=u
returnredirect(next)
else:
raiseloginError(u'错误的用户名或者密码!')
exceptloginErrorase:
returnrender_template('login.html',next=next,error=e.value)@app.route('/signout/',methods=['POST'])defsignout():
session.pop('logged_in',None)
returnredirect(url_for('home'))
I. 如何在flask中使用mysql数据库
1、首先搞明白flask框架中,一个请求的被处理过程,以及页面是如何渲染的;这一个过程中, 不需要考虑mysql, 你可以直接用list、dict这些数据结构模拟一些数据, 并让jinja2模板来显示你的数据
2、学习下mysqldb的使用
3、在flask中使用mysqldb即可
J. 在python3下怎样用flask-sqlalchemy对mysql数据库操作
这个问题经常难道新手一下,因为大部分教程里(包括经典的《Flask Web开发》一书),告诉了我们如何使用flask-sqlalchemy操作sqlite,但在生产环境(线上网站)上,我们肯定是使用MySQL或其他,而大部分的教程里,又告诉我们flask-sqlalchemy使用MySQL的方式是:
mysql://username:password@server/db
结果我们照葫芦画瓢的来一下,发现压根不行,写好的网站一跟数据库沾边就报错。
Python和MySQL是“两个国家的人”,他们互不相通,因而需要一个中间代理,让双方互通有无,跟翻译一样(这比喻不准确,但足够你明白意思就行)。翻译又有很多选择,不同的翻译各有特色。
题主解决问题选择的翻译是“flask-mysqldb”,其背后的主子是“MySQL-python”。恩,说到这里你应该知道,“flask-xxx”这样的包都是对背后主子进行了适合Flask封装的插件,跟包子皮一样,里面的馅才是重点,“flask-mysqldb”的馅是“MySQL-python”。
而我要推荐的是另一个翻译:PyMySQL,这玩意的好处是可以做异步(“MySQL-python”也可以,个人口味罢了),简而言之,网站访问量大了就需要考虑异步,现在别管这是啥子。这玩意的安装方式是:
pip install PyMySQL
之后,数据库连接由:
mysql://username:password@server/db
改为
mysql+pymysql://username:password@server/db
就可以了。