我想知道如何创建和使用从辅助数据库读取数据的模型。目前,我有以下代码用于填充下拉菜单。它位于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})
我已阅读有关数据库路由器的内容,并查看了示例。但是,我对模型的了解很少,大多数例子都与写入数据库有关。任何帮助将不胜感激。
答案 0 :(得分:1)
您提供的解决方案没有任何内在错误。数据库路由的使用主要用于属于您项目的多个数据库。如果您正在使用外部数据库(特别是那些几乎没有控制权的数据库),那么您显示的方法就可以了。
但是,可以包装外部数据库,以便可以使用Django ORM查询它。文档很好地涵盖了这个https://docs.djangoproject.com/en/dev/topics/db/multi-db/。