使用模型查询辅助外部数据库

时间:2014-04-29 23:51:12

标签: python database django model

我想知道如何创建和使用从辅助数据库读取数据的模型。目前,我有以下代码用于填充下拉菜单。它位于views.py。

views.py

def platform_pass_rate(request):
     db = MySQLdb.connect(user='a_user', db='secondary', passwd='something', host='ab-cd')
     cursor = db.cursor()
     cursor.execute('SELECT study FROM study ORDER BY study ASC')
     study_model = [row for row in cursor.fetchall()]
     cursor.execute(
          'SELECT column_name FROM information_schema.columns where table_name = 
          \'finalvalues\' order by ordinal_position')
     study_result = cursor.fetchall()
     db.close()
     study_models = [i for sub in study_model for i in sub]
     study_results = [i for sub in study_result for i in sub]

     return render_to_response("data_form_platform.html", {'our_url': current_url, 
                                                     'study_models': study_models,
                                                  'study_results': study_results})

我已阅读有关数据库路由器的内容,并查看了示例。但是,我对模型的了解很少,大多数例子都与写入数据库有关。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:1)

您提供的解决方案没有任何内在错误。数据库路由的使用主要用于属于您项目的多个数据库。如果您正在使用外部数据库(特别是那些几乎没有控制权的数据库),那么您显示的方法就可以了。

但是,可以包装外部数据库,以便可以使用Django ORM查询它。文档很好地涵盖了这个https://docs.djangoproject.com/en/dev/topics/db/multi-db/