文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

py_Django的数据库操作

2024-04-02 19:55

关注




数据库引擎



pymysql   取而代之    ----推荐

    2的话pip install pymysql
    3的话 pip3 install pymysql
    安装完成后用pip3 freeze 查看一下安装的什么版本之类的 


MySQLdb   python3不支持,也TM很久没更新了

    sudo yum install python-devel mysql-devel

    MySQL-python-1.2.5,这才是python2.7.6的mysql接口

    https://pypi.python.org/pypi/MySQL-python/1.2.5

    import MySQLdb



mysqlclient     django1.9推荐,python3.3+支持

    sudo yum install python-devel mysql-devel

    pip install mysqlclient

MySQL Connector/Python  





$ python manage.py makemigrations polls     stored as amigration.
$ python manage.py sqlmigrate polls 0001     just returns their SQL
$ python manage.py check    
# this checks for any problems in your project without making migrations or touching the database.
$ python manage.py migrate    apply those changes to the database.

会自动生成主键_id






python manage.py shell


基本数据访问

>>> from books.models import Publisher            
>>> p1 = Publisher(name='Apress', address='....)  
>>> p1.save()                                     
>>> publisher_list = Publisher.objects.all()
    
>>> publisher_list
[<Publisher: Publisher object>]

`` objects.create()``  一步完成对象的创建与存储至数据库,就不需要save

>>> p1 = Publisher.objects.create(name='Apress',
...     address='2855 Telegraph Avenue',..............


添加模块的字符串表现

Publisher 对象添加一个方法 __unicode__() 。

from django.db import models
class Publisher(models.Model):
    name = models.CharField(max_length=30)
    def __unicode__(self):
        return self.name
>>> from books.models import Publisher
>>> publisher_list = Publisher.objects.all()
>>> publisher_list
[<Publisher: Apress>, <Publisher: O'Reilly>]



插入和更新数据


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

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

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

>>> p.name = 'Apress Publishing'
>>> p.save()


注意,并不是只更新修改过的那个字段,所有的字段都会被更新。 这个操作有可能引起竞态条件


选择对象

取出所有记录:

>>> Publisher.objects.all()
[<Publisher: Apress>, <Publisher: O'Reilly>]


数据过滤

filter()返回集合

你可以传递多个参数到 filter() 来缩小选取范围:

>>> Publisher.objects.filter(country="U.S.A.", state_province="CA")
[<Publisher: Apress>]

在 name 和 contains 之间有双下划线。contains部分会被Django翻译成LIKE语句:

>>> Publisher.objects.filter(name__contains="press")
[<Publisher: Apress>]

注意,SQL缺省的 = 操作符是精确匹配的

SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE name LIKE '%press%';

其他的一些查找类型有:icontains(大小写无关的LIKE),startswithendswith, 还有range(SQLBETWEEN查询)。 附录C详细描述了所有的查找类型。


获取单个对象

`` get()`` 返回单个的对象

>>> Publisher.objects.get(name="Apress")
<Publisher: Apress>

如果结果是多个对象,会导致抛出异常,如果查询没有返回结果也会抛出异常:

DoesNotExist: Publisher matching query does not exist.

 Publisher.DoesNotExist 在你的应用中,你可以捕获并处理这个异常,像这样:

try:
    p = Publisher.objects.get(name='Apress')
except Publisher.DoesNotExist:
    print "Apress isn't in the database yet."
else:
    print "Apress is in the database."

数据排序


有序返回查询结果

如果需要以多个字段为标准进行排序(第二个字段会在第一个字段的值相同的情况下被使用到),减号 -
表示逆向排序:

>>> Publisher.objects.order_by("-state_province", "address")
 [<Publisher: Apress>, <Publisher: O'Reilly>]

Django让你可以指定模型的缺省排序方式: class Meta,内嵌类。

class Publisher(models.Model):
    name = models.CharField(max_length=30)
    
    def __unicode__(self):
        return self.name
        
    **class Meta:**
        **ordering = ['name']**


连锁查询

“链式”的形式:

>>> Publisher.objects.filter(country="U.S.A.").order_by("-name")
[<Publisher: O'Reilly>, <Publisher: Apress>]


限制返回的数据

取出固定数目的记录,剪语句,不支持负索引,但可逆序查询

>>> Publisher.objects.order_by('-name')[0:2]


更新多个对象

更新一条记录

>>> Publisher.objects.filter(id=52).update(name='Apress Publishing')

更新多条记录。

>>> Publisher.objects.all().update(country='USA')   # 所有Publisher的country字段
2                        # 表示受影响的记录条数

注:save()方法,这个方法会更新一行里的所有列。 而某些情况下,我们只需要更新行里的某几列。

删除对象

删除数据库中的对象只需调用该对象的delete()方法即可:

>>> p = Publisher.objects.get(name="O'Reilly")
>>> p.delete()
>>> Publisher.objects.all()
[<Publisher: Apress Publishing>]
>>> Publisher.objects.filter(country='USA').delete()    # 删除部分
>>> Publisher.objects.all().delete()            # 删除所有

 为了预防误删除掉某一个表内的所有数据,Django要求在删除表内所有数据时显示使用all()。 否则报错

>>> Publisher.objects.delete()            # 必需加all()
Traceback (most recent call last):
  File "<console>", line 1, in <module>
AttributeError: 'Manager' object has no attribute 'delete'







阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯