问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

django如何实现数据库查询数据库(2023年最新解答)

发布网友 发布时间:2024-09-26 20:02

我来回答

1个回答

热心网友 时间:2024-10-29 09:21

导读:今天首席CTO笔记来给各位分享关于django如何实现数据库查询数据库的相关内容,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

Django里面怎么实现数据库视图啊就是虚拟表

正经回答:先在数据库中建立好视图,然后django中建立对应的model。表所对应的类下面再建立一个Meta类,大致如下

class?ViewModel(models.Model):

????"""这个model类对应你所建立好的视图"""

????class?Meta(object):

????????"""同理,该方法可用于使用mysql中任何已有的表,不仅是视图"""

????????db_table?=?'your_view'?#显式指定表名,也就是你建立的视图的名字

????????managed?=?false?#默认是ture,设成false?django将不会执行建表和删表操作

????#?建立字段间的映射

????#??需要注意的是,必须设一个字段为主键

????#??不然django会自动创建一个id字段为主键,引发错误

百度知道越来越辣鸡了,全是答非所问的。

django中怎么使用两个限定条件在mysql数据库中进行查询

可以使用逻辑关系运算符

例如:

SELECT*FROMtable_name

WHERE(条件1and条件2)查询两个条件都符合的结果,

或者

SELECT*FROMtable_name

WHERE(条件1or条件2)查询符合两个条件中满足任一条件的结果。

如何独立使用django的数据库访问功能

1.安装Django

[plain]viewplaincopy

cdDjango-1.4

pythonsetup.pyinstall

2.安装postgresql的客户端:

[plain]viewplaincopy

sudoapt-getinstall-ypostgresql-client-9.1python-psycopg2

3.新建project:

[plain]viewplaincopy

django-admin.pystartprojectmyproject

4.在myproject下新建app:

[plain]viewplaincopy

pythonmanage.pystartappmyapp

4.新增环境变量:

编辑/etc/profile文件,在末尾加入以下语句:

[plain]viewplaincopy

spanstyle="color:#FF0000;"exportPYTHONPATH=$PYTHONPATH:/home/yc/src/myproject

exportDJANGO_SETTINGS_MODULE=myproject.settings/span

5.

假设数据库已经由Django的另一个应用(名称为otherapp)建好,数据库类型是postgresql,名称为mydb,位于

192.168.1.23。见好的数据库中有一个表,名称是otherapp_user,则将otherapp/models.py拷贝到myapp

/models.py。

注意检查models.py下的classuser类的classMeta:部分,如果没有applabel标签,则要加上:app_label='otherapp'

再修改/home/yc/src/myproject下的settings.py文件,如下:

[plain]viewplaincopy

DATABASES={

'default':{

'ENGINE':'django.db.backends.postgresql_psycopg2',#Add'postgresql_psycopg2','mysql','sqlite3'or'oracle'.

'NAME':'mydb',#'vps2db_test1'Orpathtodatabasefileifusingsqlite3.

'USER':'postgres',#Notusedwithsqlite3.

'PASSWORD':'123',#Notusedwithsqlite3.

'HOST':'192.168.1.23',#Settoemptystringforlocalhost.Notusedwithsqlite3.

'PORT':'5432',#Settoemptystringfordefault.Notusedwithsqlite3.

}

}

[plain]viewplaincopy

INSTALLED_APPS=(

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions',

'django.contrib.sites',

'django.contrib.messages',

'django.contrib.staticfiles',

'spanstyle="color:#FF0000;"myapp/span',

)

6.在myapp目录下编写测试程序

[python]viewplaincopy

frommodelsimportuser

if__name__=="__main__":

try:

u=user.objects.get(id=user_id)

exceptuser.DoesNotExist:

print"usernotexist)

returnNone

else:

returnu

django怎么从数据库取数据

Django拥有自己的ORM模块。

通俗来讲其过程如下:

在Django中写Python代码

将Python代码通过ORM模块转换成SQL语句

通过类似pymysql等数据库操作模块,使用SQL语句,前往数据库访问数据

上述过程的反方向

获取Python格式的数据

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

使用多个数据库

NewinDjango1.2:Please,seethereleasenotes

大多数其他文档都假设使用单一数据库,本文主要讨论如何在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.pysyncdb

$./manage.pysyncdb--database=users

如果你不是同步所有的程序到同一个数据库中,你可定义一个数据库路由来为指定的模型实施特定的控制策略。

如果你要精细地控制同步,那么还有一种方式是修改sqlall的输出,手工在数据库中执行命令,命令如下:

$./manage.pysqlallsales|./manage.pydbshell

使用其他管理命令

其他操作数据库的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中的模型包含与另一个数据库中模型的关系时,本例是无效的。参见跨数据库关系一节中介绍的Django引用完整性问题。

本例的主/从配置也是有缺陷的:它没有处理复制延时(比如因为把写操作传递给从数据库耗费时间而产生的查询不一致),也没有考虑与数据库使用策略的交互作用。

那么,这个例子有什么用呢?本例仅用于演示一个myapp存在于other数据库,所有其他模型之间是主/从关系,且存在于master、slave1和slave2数据库。本例使用了两个路由:

classMyAppRouter(object):"""一个控制myapp应用中模型的所有数据库操作的路由"""defdb_for_read(self,model,**hints):"myapp应用中模型的操作指向'other'"ifmodel._meta.app_label=='myapp':return'other'returnNonedefdb_for_write(self,model,**hints):"myapp应用中模型的操作指向'other'"ifmodel._meta.app_label=='myapp':return'other'returnNonedefallow_relation(self,obj1,obj2,**hints):"如果包含myapp应用中的模型则允许所有关系"ifobj1._meta.app_label=='myapp'orobj2._meta.app_label=='myapp':returnTruereturnNonedefallow_syncdb(self,db,model):"确保myapp应用只存在于'other'数据库"ifdb=='other':returnmodel._meta.app_label=='myapp'elifmodel._meta.app_label=='myapp':returnFalsereturnNoneclassMasterSlaveRouter(object):"""一个设置简单主/从定义的路由"""defdb_for_read(self,model,**hints):"所有读操作指向一个随机的从数据库"returnrandom.choice(['slave1','slave2'])defdb_for_write(self,model,**hints):"所有写操作指向主数据库"return'master'defallow_relation(self,obj1,obj2,**hints):"允许数据库池中的两个对象间的任何关系"db_list=('master','slave1','slave2')ifobj1._state.dbindb_listandobj2._state.dbindb_list:returnTruereturnNonedefallow_syncdb(self,db,model):"显示地放置所有数据库中的模型"returnTrue

然后在你的设置文件增加如下内容(把path.to.替换为你定义路由的模型的路径):

DATABASE_ROUTERS=['path.to.MyAppRouter','path.to.MasterSlaveRouter']

这个设置中,路由的顺序是很重要的,因为查询时是按这个设置中的顺序依次查询的。上例中,MyAppRouter先于MasterSlaveRouter,因此,myapp中的模型就优先于其他模型。如果DATABASE_ROUTERS设置中两个路由的顺序变换了,那么MasterSlaveRouter.allow_syncdb()会优先执行。因为MasterSlaveRouter是包罗万象的,这样就会导致所有模型可以使用所有数据库。

设置好之后让我们来运行一些代码:

#从'credentials'数据库获得数据fred=User.objects.get(username='fred')fred.first_name='Frederick'#保存到'credentials'数据库fred.save()#随机从从数据库获得数据dna=Person.objects.get(name='DouglasAdams')#新对象创建时还没有分配数据库mh=Book(title='MostlyHarmless')#这个赋值会向路由发出请求,并把mh的数据库设置为与author对象同样的#数据库mh.author=dna#这会强制'mh'实例使用主数据库...mh.save()#...但如果我们重新获取对象,就会从从数据库中获取mh=Book.objects.get(title='MostlyHarmless')

手动选择数据库

Django也提供一个可以让你通过代码完全控制数据库使用的API。手动定义数据库分配优先于路由。

为一个查询集手动选择一个数据库

你可以在查询集“链”中的任何点为查询集选择数据库。我们通过在查询集上调用using()来得到使用指定数据库的另一个查询集。

using()使用一个参数:你想要运行查询的数据库的别名。例如:

#这会运行在“缺省”数据库上。Author.objects.all()#这同样会运行在“缺省”数据库上。Author.objects.using('default').all()#这会运行在“other”数据库上。Author.objects.using('other').all()

为save()选择一个数据库

在使用Model.save()时加上using关键字可以指定保存到哪个数据库。

例如,要把一个对象保存到legacy_users数据库应该这样做:

my_object.save(using='legacy_users')

如果你不定义using,那么save()方法会根据路由分配把数据保存到缺省数据库中。

把一个对象从一个数据库移动到另一个数据库

当你已经在一个数据库中保存了一个对象后,你可能会使用save(using=...)把这个对象移动到另一个数据库中。但是,如果你没有使用恰当的方法,那么可能会出现意想不到的后果。

假设有如下的例子:

p=Person(name='Fred')p.save(using='first')#(第一句)p.save(using='second')#(第二名)

在第一名中,一个新的Person对象被保存到first数据库中。这时,p还没有一个主键,因此Django执行了一个INSERTSQL语句。这样就会创建一个主键,并将这个主键分配给p。

在第二句中,因为p已经有了一个主键,所以Django在保存对象时会尝试在新的数据库中使用这个主键。如果second数据库中没有使用这个主键,那就不会有问题,该对象会复制到新数据库。

然而,如果p的主键在second数据库中已经使用过了,那么second使用这个主键的已存在的对象将会被p覆盖。

有两种方法可以避免上述情况的发生。第一,你可以清除实例的主键。如果一个对象没有主主键,那么Django会把它看作一个新对象,在保存到second数据库中时就不会带来数据的损失:

p=Person(name='Fred')p.save(using='first')p.pk=None#清除主键。p.save(using='second')#写入一个全新的对象。

第二种方法是在save()方法中使用force_insert选项来保证Django执行一个INSERTSQL:

p=Person(name='Fred')p.save(using='first')p.save(using='second',force_insert=True)

这样可以保证名为Fred的人员在两个数据库中使用相同的主键。如果在保存到second数据库时主键已被占用,会抛出一个错误。

选择一个要删除数据的数据库

缺省情况下,一个现存对象从哪个数据库得到,删除这个对象也会在这个数据库中进行:

u=User.objects.using('legacy_users').get(username='fred')u.delete()#会从`legacy_users`数据库中删除

通过向Model.delete()方法传递using关键字参数可以定义在哪个数据库中删除数据。using的用法与save()方法中使用这个参数类似。

例如,假设我们要把一个用户从legacy_users数据库移动到new_users数据库可以使用如下命令:

user_obj.save(using='new_users')user_obj.delete(using='legacy_users')

多数据库情况下使用管理器

在管理器上使用db_manager(),可以让管理器访问一个非缺省数据库。

例如,假设你有一个操作数据库的自定义管理器User.objects.create_user()。

因为create_user()是一个管理器方法,不是一个查询集,所以你不能

用User.objects.using('new_users').create_user()。(create_user()方法

只能用于User.objects管理器,而不能用于,管理器衍生出的查询集。)解决方法是使用db_manager(),就象下面这样:

User.objects.db_manager('new_users').create_user(...)

db_manager()返回的是绑定到你指定的数据库的管理器的一个副本。

多数据库情况下使用get_query_set()

如果你在管理器中重载了get_query_set(),请确保在其父类中也调用了相同的方法(使用super())或者正确处理管理器中的_db属性(一个包含要

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
NBA下赛季常规赛MVP和总决赛MVP会是谁 吴前当选CBA常规赛MVP,他是实至名归吗? 如何申请安电表 如何申请独立电表 用电量大可以增加电表吗 出租他人铺面,原先房东已经安装过电表,因为用电量大,我想自己装电表可以... 梦见有个老人送佛画给我、让我在家供佛 ...分之一米还剩多少米如果截去四分之一还剩几分之几还剩多少米?_百度... 一根竹竿长四米,截去它的四分之三后,这根竹竿还剩全长的几分之几? ...这根绳子的几分之几后还剩下他的3/1,用去了( )m,还剩下( )_百度知... 如何做出绝顶美味的手撕茄条? “北巷邻居几家去”的出处是哪里 word怎么让表格文字居中 ...古代发兵攻打别人,一般粮草只够吃几个月?不出兵呆在家里就够吃了吗... MySQL差值查询如何用两表进行数据对比mysql两表查询取差值 超仙的古风闺蜜网名 超仙古风闺蜜网名 泉州晋江莲屿金坑养蜂场问:热天蜂蜜会冒泡沫出来 泉州晋江莲屿金坑养蜂场问:2009年泉州的中蜂烂子病损失有多少? 使用MySQLWorkbench与Yog管理数据库mysqlyog 去小模具厂做学徒怎么样 保险合同成立与生效的区别是什么? 泉州晋江莲屿金坑养蜂场问:短信叫汇款.转帐请勿上当! 查询操作使用MySQL查询两个时间之间的数据mysql两时间 天气预报符号的意义 天气符号是什么意思 福州中秋节的风俗 福州中秋节吃什么 萝卜虾皮鸡蛋馅水饺的制作方法有哪些? 塑化剂的检测项目有多少项,国家有没有相关的要求和标准? 福州中秋节的传统文化习俗有哪些 福州中秋节的风俗特点 福州独特的风俗讲究 2022福州中秋去哪里赏月 九大赏月最佳地点 如何把excel表格中的内容全部居中? 烽火战国打据点,副本出兵需要粮食吗? 表格怎样才能上下居中呢? 中国加入世界贸易组织给中国带来什么影响 怎样炒茄子条,原来不能直接下锅炒,多做2步,鲜嫩清爽入味 手撕茄子怎么做更好吃? 夏日开胃餐#传统家常炒茄子条的做法 社保卡挂失办理流程是什么? 现在做袜子专卖店怎么样呀 我想这种一站式的袜业专卖店 不知道行不行... 蒸茄子的做法怎么做好吃又简单 怎么匿名举报贪污 NDS SCSD 金手指 尿潴留能自愈吗 如果我想买造船股是中国船舶还是广船国际好啊? 头挂什么科 发些哪些才可以挽回男人 那样说他回你 结婚点蜡烛有哪些规矩 结婚点蜡烛有什么寓意 塞尔达传说幻影沙漏SCSD怎么玩不了呢? 女性尿潴留的治疗方法 怎样蒸茄子好吃又简单 做茄子的技巧有什么