使用Flask_SQLAlchemy连接多个数据库
- #!/usr/bin/env python
- #-*- coding: utf-8 -*-
- from flask import Flask
- from flask_sqlalchemy import SQLAlchemy
- app = Flask(__name__)
- # 配置多个数据库连接
- SQLALCHEMY_BINDS = {
- 'users': 'sqlite:///users.db',
- 'appmeta': 'sqlite:///appmeta.db'
- }
- app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///test.db' # 默认数据库引擎
- app.config['SQLALCHEMY_BINDS'] = SQLALCHEMY_BINDS
- app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
- db = SQLAlchemy(app)
- class News(db.Model):
- __tablename__ = 'news' # 未设置__bind_key__,则采用默认的数据库引擎
- id = db.Column(db.Integer, primary_key=True)
- news_title = db.Column(db.String(80), unique=True)
- news_content = db.Column(db.String(120), unique=True)
- def __init__(self, news_title, news_content):
- self.news_title = news_title
- self.news_content = news_content
- def __repr__(self):
- return '<news_title %r>' % self.news_title
- class User(db.Model):
- __bind_key__ = 'users' # 已设置__bind_key__,则采用设置的数据库引擎
- __tablename__ = 'user'
- 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
- class Article(db.Model):
- __bind_key__ = 'appmeta'
- __tablename__ = 'article'
- id = db.Column(db.Integer, primary_key=True)
- title = db.Column(db.String(80), unique=True)
- content = db.Column(db.String(120), unique=True)
- def __init__(self, title, content):
- self.title = title
- self.content = content
- def __repr__(self):
- return '<Title %r>' % self.title
- db.create_all() # 未指定bind,则使用默认的数据库引擎
- db.create_all(bind='users') # 指定bind,则使用指定的数据库引擎
- db.create_all(bind='appmeta')
- news = News('ha','hahahhahaha') # 自动关联到相对应的ORM模型,进而使用相关联的数据库引擎
- db.session.add(news) # 插入一条数据
- db.session.commit()
- admin = User('admin', 'admin@example.com')
- guest = User('guest', 'guest@example.com')
- db.session.add_all([admin,guest]) # 插入多条数据
- db.session.commit()
- title = Article('title1', 'content1')
- db.session.add(title)
- db.session.commit()
- """
- 执行该文件,会自动生成三个数据库文件:appmeta.db,users.db,test.db
- 每个数据库中插叙的有相对应的数据
- """
使用Flask_SQLAlchemy连接多个数据库的更多相关文章
- python 使用pymssql连接sql server数据库
python 使用pymssql连接sql server数据库 #coding=utf-8 #!/usr/bin/env python#------------------------------ ...
- NetBeans连接SQL server数据库教程
不废话,直接开始 1.下载sqljdbc.jar 可以从微软中国官方网站下载 SQLJDBC微软中国 笔者提供一个网盘链接Sqljdbc.jar 4个压缩包视版本选择,SQL 2012 用sqljdb ...
- CI连接多个数据库
参考http://codeigniter.org.cn/user_guide/database/connecting.html手册 首先,在database.php中设置多个数据库的连接信息,这里命名 ...
- 【转】PowerShell 连接SQL Server 数据库 - ADO.NET
转至:http://www.pstips.net/connect-sql-database.html PowerShell 通过ADO.NET连接SQL Server数据库,并执行SQL脚本.工作中整 ...
- JDBC连接sql server数据库及其它
JDBC连接sql server数据库的步骤如下: 1.加载JDBC驱动程序: 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), 这通过java.lang.Class类的 ...
- 通过MSSQL连接服务器连接至Oracle数据库
前言 有很多时候,我们需要MSSQL与Oracle进行跨库查询或数据交互.本篇随笔将阐述如何通过MSSQL的连接服务器连接至Oracle数据库,并且读取数据的示例. 具体步骤 首先需要到Oracle的 ...
- DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常
最近,DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常. 版本说明 commons-dbcp-1.4.jar commons-pool-1 ...
- ThinkPHP连接sql server数据库
亲身经历,在网上找连接sql server数据库的方法,还是不好找的,大多数都是照抄一个人的,而这个人的又写的不全,呵呵,先介绍一下我连接的方法吧.如果你是用THINKPHP连接,那么最重要的就是配置 ...
- 查找当前SQL Server下的Active Session正连接着哪个数据库
今天碰到个事.原本想把数据库设为单用户模式然后把REMOVE FILE.没想到悲剧了.因为很多进程都是需要远程连接这个库,导致别的进程抢在我前面连接了这个数据库,反到我连不上了.想把数据库切回MULT ...
随机推荐
- 王立平--Http中Get() 与 Post()的差别?
Http协议是基于TCP协议的,而TCP协议是一种有连接.可靠的传输协议.假设丢失的话,会重传.所以这种话,就 不会有数据的丢失了. 而Http协议有三种方法.Get,Post,Head方法.可是用的 ...
- 数学之路-python计算实战(4)-Lempel-Ziv压缩(2)
Format characters have the following meaning; the conversion between C and Python values should be o ...
- 【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字
题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2.3.2,2.2.5,4.2}, 因为数组中数字2出现了5次,超过数组的长度的一半,因此输出2 ...
- linux命令之man和info
linux命令之man和info man ➜ ~ man ls result: LS(1)中1这样的数字的意义例如以下所看到的: 代号 内容 1 用户在shell环境中能够操作的命令或可运行文件 2 ...
- 【POJ 2891】 Strange Way to Express Integers
[题目链接] http://poj.org/problem?id=2891 [算法] exgcd [代码] #include <algorithm> #include <bitset ...
- HttpServletRequest对象小结
当客户端通过HTTP协议访问服务器时,请求所有信息都封装在HttpServletRequest对象中,可通过它获取到请求的所有信息,其常用方法如下: getRequestURL方法返回客户端发出请求时 ...
- redis安装及连接(入门)
安装 环境:本地win10,虚拟机里ubuntu, 在ubuntu安装redis服务,本地java连接. 本教程使用的最新文档版本为 4.0.9,下载并安装: 安装步骤: 1,进入ubuntu合适目录 ...
- 二、SQL系列之~常见51道SQL查询语句
[写在前面~~] [PS1:建议SQL初学者一定要自己先做一遍题目,这样才有效果~~(做题时为验证查询结果是否正确,可更改表中数据)] [PS2:文末最后一条代码整合了全部51道题目及答案~~] [P ...
- .Net Core Autofac实现依赖注入
Autofac 是一款适用于Microsoft .NET 4.5, Silverlight 5, Windows Store apps, and Windows Phone 8 apps的超赞的 Io ...
- maven 打包jar && lib
一.springboot 打包成jar 1.pom.xml <build> <!-- jar的名称--> <finalName>shiro</finalNam ...