草庐IT

Django-MySQLdb

全部标签

mysql - 使用遗留数据库在 Django 项目中使用复合主键

我有一个遗留数据库,其中一些表包含复合主键。我通过运行manage.pyinspectdb命令获得的模型如下所示。classMyTable(models.Model):field1_id=models.IntegerField(db_column='field1id',primary_key=True)is_favorite=models.BooleanField(db_column='isfavorite',default=False,null=False)is_admin=models.BooleanField(db_column='isadmin',default=False,n

python - Django 测试失败,内部错误 : no such savepoint. DB : Postgres, 通过 mysql

有趣的是,它也适用于shell。[MYcodewhichcallsModel.objects.get_or_create(...)]File"/usr/lib/python2.5/site-packages/django/db/models/manager.py",line123,inget_or_createreturnself.get_query_set().get_or_create(**kwargs)File"/usr/lib/python2.5/site-packages/django/db/models/query.py",line308,inget_or_createtr

python - 强制 mysqldb dict 游标返回带有表名的所有列名前缀

SELECT*FROMa,bWHERE...Mysql允许在查询结果中出现重复的列名。因此,在终端中,没有任何列名称使用上述查询作为前缀。但是,我在python中将mysqldb与DictCursor一起使用。结果是一个字典列表,其中列名是键。有时,字典游标会自动在列名前添加表名前缀。据我所知,它对两个不明确的列名中的第二个执行此操作,但前提是第二个值是唯一的。无论如何,我想强制光标在所有键前加上表名。来自mysqldbdocs在fetch.row()函数上...Thesecondparameter(how)tellsithowtherowshouldberepresented.Byd

python - 使用 MySQLdb 在 Python 中执行 .sql 文件

我有一个包含一堆SQL查询的.sql文件,每个查询跨越多行。我想使用MySQLdb通过Python在MySQL中执行这些查询。sqlite3has"anonstandardshortcut"forthispurposecalledexecutescript(),但在MySQLdb中似乎没有任何等效函数。我注意到了thisoldquestionfrom2yearsago问同样的事情,但我发现答案不令人满意。答案基本上是:Usesubprocesstorunthemysqlcommandandsendityour.sqlfile.这是可行的,但它相当不优雅,并且它引入了不必要的错误处理等复

Django 数据库连接丢失

在Django工程中,有时候我们需要在服务器上执行一些脚本。这些脚本需要Django的运行环境,还需要做一些ORM操作。一般大概流程如下:importosos.environ.setdefault('DJANGO_SETTINGS_MODULE','project.settings')importdjangodjango.setup()fromapp.tasksimportsometaskif__name__=='__main__':#做一些任务,一般是消费者模型下的consumesometask.consume()但这里非常容易出现一个错误,就是隔一阵子,脚本就会崩溃,并报如下错误:djan

python - Django 查询性能

我有一个关于Django查询的与性能相关的问题。假设我有一张包含10,000条记录的员工表。现在,如果我想随机选择5名年龄大于或等于20岁的员工,假设有5,500名员工年龄在20岁或以上。Django查询将是:Employee.objects.filter(age__gte=20).order_by('?')[:5]这个查询在mysql中的原始对应将是:SELECT*FROM`database`.`employee`WHERE`employee`.`age`>=20ORDERBYRAND()LIMIT5;从django查询的外观来看,数据库首先返回5,500条记录,然后python随机

mysql - Django 从 MySQL 迁移到 Postgres

我最近决定从MySQL切换到Postgres,因为我遇到了一些问题,而这些问题在Postgres上本不应该成为问题。但是我似乎找不到一个好的迁移方法我已经查看了py-mysql2pgsql但这导致了数据库中的问题我无法追踪。我还使用django-admin.py查看了dumpdata和loaddata但是我的数据库相当大并且它消耗了我所有的内存并且只是崩溃了所以我然后转移到django-dumpdata-chunks只是错误但是然后又是项目两岁了。我想问的是,这里有没有人知道从mysql迁移到postgres的可靠方法而不破坏数据库,并且如果可能的话在不停机的情况下作为奖励?

mysql - Django 偶尔无法连接到数据库(Centos)

我有一个非常奇怪的问题,我有一个运行mod_wsgi的Apache服务器。该网站运行良好,但每隔一段时间我就会收到IOError:failedtowritedata网站所有页面上的错误。然后我用解决了sudoservicemysqldrestart由于网站不能宕机太久,我没有时间去调试这个问题,每次出现这种情况我都直接运行命令。我只在日志中看到错误,这就是我无法真正调试它的原因,而且它没有明确的复制步骤,它只是随机发生。如有任何帮助,我们将不胜感激,如果您需要我发布任何配置文件,请告诉我。编辑:django显示的确切错误是:(2002,"Can'tconnecttolocalMySQL

mysql - Django admin - 模型对 super 用户可见,对员工用户不可见

我知道syncdb和makemigrations,但我们只能在生产环境中使用。我们最近在生产环境中创建了几个表。正如预期的那样,表在管理员中对任何用户都是不可见的。发布之后,我们在生产sql上手动执行了以下2个查询(我在本地运行迁移并执行showcreatetable查询以获取原始sql)django_content_typeINSERTINTOdjango_content_type(name,app_label,model)values('linked_urls',"urls",'linked_urls');auth_permissionINSERTINTOauth_permissi

python - 根据 Django 中的项目分组进行分页

对于在Django/Python中实现的网站,我们有以下要求:在View页面上,每个网页显示15条消息。当来自同一来源的两条或多条消息在View中相互跟随时,应将它们分组在一起。可能不是很清楚,但是用下面的例子可能是:一个例子是(这次页面上有5条消息):Message1Source1Message2Source2Message3Source2Message4Source1Message5Source3...这应该显示为:Message1Source1Message2Source2(clickhereto1moremessagefromSource2)Message4Source1Mes