在python的django框架中更新数据库数据的方法

先使用一些关键参数创建对象实例,如下:

>>> p = publisher(name=’apress’,
… address=’2855 telegraph ave.’,
… city=’berkeley’,
… state_province=’ca’,
… country=’u.s.a.’,
… website=’http://www.apress.com/’)

这个对象实例并 没有 对数据库做修改。 在调用“ save()“ 方法之前,记录并没有保存至数据库,像这样:

>>> p.save()

在sql里,这大致可以转换成这样:

insert into books_publisher
(name, address, city, state_province, country, website)
values
(‘apress’, ‘2855 telegraph ave.’, ‘berkeley’, ‘ca’,
‘u.s.a.’, ‘http://www.apress.com/’);

因为 publisher 模型有一个自动增加的主键 id ,所以第一次调用 save() 还多做了一件事: 计算这个主键的值并把它赋值给这个对象实例:

>>> p.id
52 # this will differ based on your own data

接下来再调用 save() 将不会创建新的记录,而只是修改记录内容(也就是 执行 update sql语句,而不是 insert 语句):

>>> p.name = ‘apress publishing’
>>> p.save()

前面执行的 save() 相当于下面的sql语句:

update books_publisher set
name = ‘apress publishing’,
address = ‘2855 telegraph ave.’,
city = ‘berkeley’,
state_province = ‘ca’,
country = ‘u.s.a.’,
website = ‘http://www.apress.com’
where id = 52;

注意,并不是只更新修改过的那个字段,所有的字段都会被更新。 这个操作有可能引起竞态条件,这取决于你的应用程序。 请参阅后面的“更新多个对象”小节以了解如何实现这种轻量的修改(只修改对象的部分字段)。

update books_publisher set
name = ‘apress publishing’
where id=52;

选择对象

当然,创建新的数据库,并更新之中的数据是必要的,但是,对于 web 应用程序来说,更多的时候是在检索查询数据库。 我们已经知道如何从一个给定的模型中取出所有记录:

>>> publisher.objects.all()
[,