我将在我当前的应用程序中使用django-dbbackup。我的任务是在从UI按下“备份数据库”按钮时使用custom_name.db备份我最新的sqlite3数据库,并在按下“恢复此备份”时从现有备份列表中恢复备份。
在django-dbbackup中有两个管理命令,dbbackup和dbrestore用作
dbbackup [-s <servername>] [-d <database>] [--clean] [--compress] [--encrypt]
和
dbrestore [-d <database>] [-s <servername>] [-f <localfile>]
现在我的问题是,如果我有原始数据库名称original_db.db并且我想将此db重命名备份为db_current_data_time.db,那么views.py方法应该是什么?
您可以使用manage.py
调用call_command
运行的命令
from django.core import management
management.call_command('your_command', your_options)
因此,在各自的备份和还原视图中,您可以调用命令。
虽然你可以使用call_command
来调用管理命令,但它确实不太理想。管理命令应该由人从shell以交互方式运行,而不是从视图中调用。
如果要同时提供管理命令和Web操作,请将管理命令的内容移动到单独的函数中(我建议使用myapp/operations/foo
)。然后重构您的管理命令以利用此独立功能。一旦它工作,重构您的视图以调用相同的操作(函数),传入相同的参数。
这将允许管理命令和视图之间的最佳代码共享,并使您的核心逻辑的编写测试更加清晰。