在操作数据库的业务里,我们系统采用了orm框架 ,避免了过多的写sql,利用实体对数据库进行操作

需求: 账户系统里的account表是进行了分表,分表规则为accountid进行20取模,测试环境分为多套环境

a,b,c环境,需要在对数据库操作时区分环境

1、使用sqlalchemy

base = declarative_base()

def get_model(name,env):

if. env =='a':

engine = create_engine('mysql+pymysql.....这里是a环境的配置')

elif env =='b':

.......

base.metadata.reflect(engine)

table = base.metadata.table[name]

mapper(t, table)

Base.metadata.clear()

return t

当然这里的参数name是需要额外做处理的,因为存在分表的规则,所以需要在先得到具体的表名再找到对应的model

2、使用flask_sqlalchemy

通过元类编程找出对应的model

class Account(object):

__mapper = {}
   @staticmethod
   def model( account_id, env = 'c'):
   if env == 'c':
      app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:root@xxxx'
   else :
     app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://root:root@xxx'
   app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True
   db =SQLAlchemy(app)
   table_index = account_id%20
   class_name='account_%d' % table_index
   ModelClass = Account.__mapper.get(class_name, None)
   if ModelClass is None:
        ModelClass = type(class_name, (db.Model,),
           {
             '__module__':__name__,
             '__name__':class_name,
             '__tablename__':'account_%d' % table_index,
             'account_id':db.Column(db.Integer, primary_key=True),
             'main_id':db.Column(db.Integer)

})
      Account.__mapper[class_name]=ModelClass

cls = ModelClass()
      cls.account_id = account_id
   return cls

最新文章

  1. 基础算法(javascipt)总结
  2. spring mvc统一异常处理(@ControllerAdvice + @ExceptionHandler)
  3. svn利用钩子实现代码同步到web目录
  4. IMX6下移植WKxxx驱动
  5. CentOS 7 中firewall-cmd命令
  6. Cache的原理、设计及实现
  7. 缓存管理Memorycache 的使用
  8. ubuntu增加工作分区(workspace)命令
  9. HDU 5274(树链剖分)
  10. C# 零散笔记
  11. 利用ant的javac任务来编译java程序
  12. 1601: [Usaco2008 Oct]灌水
  13. 最新城市二级联动json(2017-09)
  14. android布局Relative和gridLayout-android学习之旅(十六)
  15. 《Hadoop金融大数据分析》读书笔记
  16. openstack搭建之-keystone配置(8)
  17. Centos7配置SVN服务端
  18. ElastichSearch漏洞
  19. cookies、sessionStorage和localStorage解释及区别
  20. 数的全排列 dfs深度优先搜索

热门文章

  1. linux完整卸载mysql数据库
  2. Java验证身份证是否合法
  3. PHP大文件上传断点续传解决方案
  4. PyCharm中Qt Designer+PyUIC配置
  5. Selenium 文件下载
  6. idea中JSP页面不能访问静态资源(图片,js,css)
  7. Java常考面试题整理(五)
  8. 状压dfs小记
  9. Android-Universal-Image-Loader的缓存处理机制与使用 LruCache 缓存图片
  10. C#的语音识别 using System.Speech.Recognition;