1. #!/usr/bin/env python
  2. #-*- coding: utf-8 -*-
  3.  
  4. from flask import Flask
  5. from flask_sqlalchemy import SQLAlchemy
  6.  
  7. app = Flask(__name__)
  8.  
  9. # 配置多个数据库连接
  10. SQLALCHEMY_BINDS = {
  11. 'users': 'sqlite:///users.db',
  12. 'appmeta': 'sqlite:///appmeta.db'
  13. }
  14.  
  15. app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///test.db' # 默认数据库引擎
  16. app.config['SQLALCHEMY_BINDS'] = SQLALCHEMY_BINDS
  17. app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
  18.  
  19. db = SQLAlchemy(app)
  20.  
  21. class News(db.Model):
  22. __tablename__ = 'news' # 未设置__bind_key__,则采用默认的数据库引擎
  23.  
  24. id = db.Column(db.Integer, primary_key=True)
  25. news_title = db.Column(db.String(80), unique=True)
  26. news_content = db.Column(db.String(120), unique=True)
  27.  
  28. def __init__(self, news_title, news_content):
  29. self.news_title = news_title
  30. self.news_content = news_content
  31.  
  32. def __repr__(self):
  33. return '<news_title %r>' % self.news_title
  34.  
  35. class User(db.Model):
  36. __bind_key__ = 'users' # 已设置__bind_key__,则采用设置的数据库引擎
  37. __tablename__ = 'user'
  38.  
  39. id = db.Column(db.Integer, primary_key=True)
  40. username = db.Column(db.String(80), unique=True)
  41. email = db.Column(db.String(120), unique=True)
  42.  
  43. def __init__(self, username, email):
  44. self.username = username
  45. self.email = email
  46.  
  47. def __repr__(self):
  48. return '<User %r>' % self.username
  49.  
  50. class Article(db.Model):
  51. __bind_key__ = 'appmeta'
  52. __tablename__ = 'article'
  53.  
  54. id = db.Column(db.Integer, primary_key=True)
  55. title = db.Column(db.String(80), unique=True)
  56. content = db.Column(db.String(120), unique=True)
  57.  
  58. def __init__(self, title, content):
  59. self.title = title
  60. self.content = content
  61.  
  62. def __repr__(self):
  63. return '<Title %r>' % self.title
  64.  
  65. db.create_all() # 未指定bind,则使用默认的数据库引擎
  66. db.create_all(bind='users') # 指定bind,则使用指定的数据库引擎
  67. db.create_all(bind='appmeta')
  68.  
  69. news = News('ha','hahahhahaha') # 自动关联到相对应的ORM模型,进而使用相关联的数据库引擎
  70. db.session.add(news) # 插入一条数据
  71. db.session.commit()
  72.  
  73. admin = User('admin', 'admin@example.com')
  74. guest = User('guest', 'guest@example.com')
  75. db.session.add_all([admin,guest]) # 插入多条数据
  76. db.session.commit()
  77.  
  78. title = Article('title1', 'content1')
  79. db.session.add(title)
  80. db.session.commit()
  81.  
  82. """
  83. 执行该文件,会自动生成三个数据库文件:appmeta.db,users.db,test.db
  84. 每个数据库中插叙的有相对应的数据
  85. """

使用Flask_SQLAlchemy连接多个数据库的更多相关文章

  1. python 使用pymssql连接sql server数据库

    python 使用pymssql连接sql server数据库   #coding=utf-8 #!/usr/bin/env python#------------------------------ ...

  2. NetBeans连接SQL server数据库教程

    不废话,直接开始 1.下载sqljdbc.jar 可以从微软中国官方网站下载 SQLJDBC微软中国 笔者提供一个网盘链接Sqljdbc.jar 4个压缩包视版本选择,SQL 2012 用sqljdb ...

  3. CI连接多个数据库

    参考http://codeigniter.org.cn/user_guide/database/connecting.html手册 首先,在database.php中设置多个数据库的连接信息,这里命名 ...

  4. 【转】PowerShell 连接SQL Server 数据库 - ADO.NET

    转至:http://www.pstips.net/connect-sql-database.html PowerShell 通过ADO.NET连接SQL Server数据库,并执行SQL脚本.工作中整 ...

  5. JDBC连接sql server数据库及其它

    JDBC连接sql server数据库的步骤如下: 1.加载JDBC驱动程序: 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), 这通过java.lang.Class类的 ...

  6. 通过MSSQL连接服务器连接至Oracle数据库

    前言 有很多时候,我们需要MSSQL与Oracle进行跨库查询或数据交互.本篇随笔将阐述如何通过MSSQL的连接服务器连接至Oracle数据库,并且读取数据的示例. 具体步骤 首先需要到Oracle的 ...

  7. DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常

    最近,DBCP连接Oracle,数据库重启后现OALL8 is in an inconsistent state异常. 版本说明 commons-dbcp-1.4.jar commons-pool-1 ...

  8. ThinkPHP连接sql server数据库

    亲身经历,在网上找连接sql server数据库的方法,还是不好找的,大多数都是照抄一个人的,而这个人的又写的不全,呵呵,先介绍一下我连接的方法吧.如果你是用THINKPHP连接,那么最重要的就是配置 ...

  9. 查找当前SQL Server下的Active Session正连接着哪个数据库

    今天碰到个事.原本想把数据库设为单用户模式然后把REMOVE FILE.没想到悲剧了.因为很多进程都是需要远程连接这个库,导致别的进程抢在我前面连接了这个数据库,反到我连不上了.想把数据库切回MULT ...

随机推荐

  1. 很实用的50个CSS代码片段

    原文:50 Useful CSS Snippets Every Designer Should Have          面对每年如此多的 新趋势 ,保持行业的率先是个非常困难问题. 站点设计者和前 ...

  2. linux c 操作utmp 和 wtmp 文件接口

    /var/run/utmp 保存当前在本系统中的用户信息 /var/log/wtmp 保存登陆过本系统的用户信息 他们保存的信息是基于结构体 struct utmp 的(/usr/include/bi ...

  3. selenium找到页面元素click没反应

    问题描述:通过调试可以看到控制台已经找到了起诉入口页面元素,可是点击“我是原告”没有反应了,也没有报错 解决办法:登录时是跳进了两层的iframe中,需要跳出iframe才能找到我是原告.

  4. linux for LVM 创建笔记

    LVM: 1.创建pv(物理卷) [root@localhost dev]# pvcreate /dev/sdd /dev/sde /dev/sdf Writing physical volume d ...

  5. luogu2242 公路维修问题

    题目大意 把一个高速公路看作由连续排列的一个个格子组成,有n个格子上有坑.给出m,要求出m段区间,使得这m区间覆盖到所有坑(交通管制),且占据的格子数量最少.输出占据的格子数. 题解 换个角度看问题. ...

  6. 通用扩展函数之TypeParse

    代码实现: ".TryToInt();//转换为int失败返回0 var int2 = "2x".TryToInt(); );//转换为int失败返回1 ); " ...

  7. Java IO-InputStream家族 -装饰者模式

    最近看到一篇文章,初步介绍java.io.InputStream,写的非常通俗易懂,在这里我完全粘贴下来. 来源于 https://mp.weixin.qq.com/s/hDJs6iG_YPww7ye ...

  8. JXOI2019 退役记

    day0 考前一天在机房和RyeCatcher,还有高一数竞大佬wyt一起颓三国杀,被深深吸引无法自拔,所谓大考大浪,也算是缓解缓解压力 刷刷空间发现好多外地OIer都赶到江科了,萌生出去见一见我江西 ...

  9. 使用autofac在mvc5下依赖注入

    把遇到的问题汇总一下: 一.安装mvc5版本 命令:pm> Install-Package Autofac 结果安装的Autofac.Integration.Mvc(版本为4.0),所引用的依赖 ...

  10. Rsync同步神器

    Rsync清理大批量垃圾数据 在Linux下删除海量文件的情况,需要删除数十万个文件.这个是之前的程序写的日志,增长很快,而且没什么用.这个时候,我们常用的删除命令rm -fr * 就不好用了,因为要 ...