热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

django用的mysql数据库,删除数据时索引也就随之删除了,索引就不规律了,如和能让删除数据时索引不变?

django用的mysql数据库,删除数据时索引也就随之删除了,索引就不规律了,如和能让删除数据时索引不变?这个id依然是规律的。比如你原来有1、2、3、4、5、6、7、8、9个i

django 用的mysql数据库,删除数据时索引也就随之删除了,索引就不规律了,如和能让删除数据时索引不变?

这个id依然是规律的。 比如你原来有1、2、3、4、5、6、7、8、9个id号码,结果删掉了3和7这两个id。

接下来你新建的id会依然自动的从10开始,而不是你想象中认为的将3和7补齐。

这是Django的默认规则。除非你手动指定id,前提是不产生冲突。 一般情况,不要去人为控制id这个自动字段,而是自己设计一个专门的字段做这方面的考虑,进行排序、过滤、索引等等方面的工作。

Django的多数据库问题,怎么解决

选择开始菜单中→程序→【Management SQL Server 2008】→【SQL Server Management Studio】命令,打开【SQL Server Management Studio】窗口,并使用Windows或 SQL Server身份验证建立连接。在【对象资源管理器】窗口中展开服务器,然后选择【数据库】节点右键单击【数据库】节点,从弹出来的快捷菜单中选择【新建数据库】命令。

执行上述操作后,会弹出【新建数据库】对话框。

在对话框、左侧有3个选项,分别是【常规】、【选项】和【文件组】。完成这三个选项中的设置会后,就完成了数据库的创建工作,在【数据库名称】文本框中输入要新建数据库的名称。例如,这里以“新建的数据库”。在【所有者】文本框中输入新建数据库的所有者,如sa。

根据数据库的使用情况,选择启用或者禁用【使用全文索引】复选框。在【数据库文件】列表中包括两行,一行是数据库文件,而另一行是日记文件。通过单击下面的【添加】、【删除】按钮添加或删除数据库文件。

切换到【选项页】、在这里可以设置数据库的排序规则、恢复模式、兼容级别和其他属性。切换到【文件组】页,在这里可以添加或删除文件组。完成以上操作后,单击【确定】按钮关闭【新建数据库】对话框。

至此“新建的数据”数据库创建成功。新建的数据库可以再【对象资源管理器】窗口看到。

django中怎么动态操作数据库字段?

django的ORM系统不支持修改删除字段的操作,也就是说你在写模型model文件的时候,比如说定义了这个user表,然后包含字段telphone定义,你一旦执行了manage.py syncdb 这个操作,就把表结构往数据库写死了,如果你之是删除了model文件的telphone,数据库是不被重新修改的。这个时候必须用原生SQL解决,也就是说自己写SQL语句让django执行,这样的话会出很多问题,也就是说你执行了alter table users drop column telphone之后,你的model文件不知道你已经对users表结构做了修改,这样会出直接导致django应用的崩溃。

所以动态字段不好做。

也可能是我才疏学浅,没太理解,也许有高人能做到。不过面对ORM这样的尽量别删除字段。

若删除已有的数据库必先将其关闭 对还是错

对。 方法如下: 1、在开始菜单中找到“控制面板”,单击打开“控制面板”。 2、在“控制面板”中,找到“系统和安全”,单击打开。 3、在“控制面板”>>“系统和安全”窗口,单击打开“管理工具”。 4、在“控制面板”系统和安全”“管理工具”窗口,双击打开“服务”。 5、找到Oracle实例服务,单击右键选择"停止",或点击左边栏“停止此服务”。 6、找到Oracle的监听服务,单击右键选择"停止",或点击左边栏“停止此服务”。 方法如下: 1、在开始菜单中找到“控制面板”,单击打开“控制面板”。

2、在“控制面板”中,找到“系统和安全”,单击打开。

3、在“控制面板”>>“系统和安全”窗口,单击打开“管理工具”。 4、在“控制面板”系统和安全”“管理工具”窗口,双击打开“服务”。 5、找到Oracle实例服务,单击右键选择"停止",或点击左边栏“停止此服务”。 6、找到Oracle的监听服务,单击右键选择"停止",或点击左边栏“停止此服务”。

求教,django的数据库错误的解决方法

(1)site matching query does not exist. lookup parameters were 'pk' 1 一般发生在数据库没有设置好,直接开启adminSite并运行了syncdb,造成数据结构不全,重新删除所有DJANGO_*,AUTH_*后重新运行syncdb问题解决。

如何在django中使用多个数据库

使用多个数据库New in Django 1.2: Please, see the release notes大多数其他文档都假设使用单一数据库,本文主要讨论如何在 Django 中使用多个数据库。 使用多个数据库,要增加一些步骤。

定义你的数据库 使用多数据库的第一步是通过 DATABASES 设置要使用的数据库服务。

这个 设置用于映射数据库别名和特定的联结设置字典,这是 Django 定义数据库一贯的手法。 字典内部的设置参见 DATABASES 文档。 数据库可以使用任何别名,但是 default 有特殊意义。当没有选择其他数据库时, Django 总是使用别名为 default 的数据库。

因此,如果你没有定义一个名为 default 的数据库时,你应当小心了,在使用数据库前要指定你想用的数据库。 以下是一个定义两个数据库的 settings.py 代码片断。定义了一个缺省的 PostgreSQL 数据库和一个名为 users 的 MySQL 数据库: DATABASES = { 'default': { 'NAME': 'app_data', 'ENGINE': 'django.db.backends.postgresql_psycopg2', 'USER': 'postgres_user', 'PASSWORD': 's3krit' }, 'users': { 'NAME': 'user_data', 'ENGINE': 'django.db.backends.mysql', 'USER': 'mysql_user', 'PASSWORD': 'priv4te' } } 如果你尝试访问 DATABASES 设置中没有定义的数据库, Django 会抛出一个 django.db.utils.ConnectionDoesNotExist异常。

同步你的数据库 syncdb 管理命令一次只操作一个数据库。缺省情况下,它操作 default 数据库。但是加上 --database 参数,你可以让 syncdb 同步不同的 数据库。

所以要同步我们例子中的所有数据库的所有模型可以使用如下命令: $ ./manage.py syncdb$ ./manage.py syncdb --database=users如果你不是同步所有的程序到同一个数据库中,你可定义一个 数据库路由 来为指定的模型实施特定的控制 策略。 如果你要精细地控制同步,那么还有一种方式是修改 sqlall 的输出,手工在 数据库中执行命令,命令如下: $ ./manage.py sqlall sales | ./manage.py dbshell使用其他管理命令 其他操作数据库的 django-admin.py 命令与 syncdb 类似,他们一次只 操作一个数据库,使用 --database 来控制使用哪个数据库。 自动数据库路由 使用多数据库最简单的方法是设置一个数据库路由方案。

缺省的路由方案确保对象 “紧贴”其原本的数据库(例如:一个对象从哪个数据库取得,就保存回哪个数据库)。 缺省的路由方案还确保如果一个数据库没有指定,所有的查询都会作用于 缺省 数据 库。 你不必为启动缺省路由方案作任何事,因为它是“开箱即用”的。但是,如果你要执行 一些更有趣的数据库分配行为的话,你可以定义并安装你自己的数据库路由。

数据库路由 一个数据库路由是一个类,这个类最多有四个方法: db_for_read(model, **hints) 建议 model 对象写操作时使用的数据库。 如果一个数据库操作可以提供对选择数据库有用的附加信息,那么可以通过 hints 字典提供。详见 下文 。 如果没有建议则返回 None 。

db_for_write(model, **hints) 建议 model 对象读操作时使用的数据库。 如果一个数据库操作可以提供对选择数据库有用的附加信息,那么可以通过 hints 字典提供。详见 下文 。 如果没有建议则返回 None 。

allow_relation(obj1, obj2, **hints) 当 obj1 和 obj2 之间允许有关系时返回 True ,不允许时返回 False ,或者没有 意见时返回 None 。这是一个纯粹的验证操作,用于外键和多对多操作中,两个对象 的关系是否被允许。 allow_syncdb(db, model) 决定 model 是否可以和 db 为别名的数据库同步。

如果可以返回 True , 如果不可以返回 False ,或者没有意见时返回 None 。这个方法用于决定一个给定 数据库的模型是否可用。 一个路由不必提供 所有 这些方法,可以省略其中一个或多个。

如果其中一个方法被 省略了,那么 Django 会在执行相关检查时跳过相应路由。 提示参数 数据库路由接收的“提示”参数可用于决定哪个数据库应当接收一个给定的请求。 目前,唯一可以提供的提示参数是 实例 ,即一个与读写操作相关的对象的实例。 可以是一个已保存的对象的实例,也可以是一个多对多关系中添加的实例。

在某些情况下, 也可能没有对象的实例可以提供。路由会检查提示实例是否存在,并相应地决定是否改变 路由行为。 使用路由 数据库路由使用 DATABASE_ROUTERS 设置来安装。

这个设置定义一个类名称 列表,每个类定义一个用于主路由 (django.db.router) 的路由。 主路由用于 Django 分配数据库操作。当一个查询想要知道使用哪个数据库时,会提供 一个模型和一个提示(如果有的话),并调用主路由。 Django 就会按次序尝试每个路由, 直到找到合适的路由建议。

如果找不到路由建议就会尝试实例提示的当前的 _state.db 。如果没有提供路由提示,或者实例没有当前数据库状态,那么主路由会 分配 缺省 数据库。 一个例子 仅用于示例目的! 这个例子仅用于展示路由如何改变数据库的使用。

本例有意忽略了一些复杂的东西以 便于更好的展示路由是如何工作的。 如果任何一个 myapp 中的模型包含与 另一个 数据库中模型的关系时。


推荐阅读
author-avatar
欧阳闯恋365
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有