Django学习笔记二:数据库操作详解

Django框架提供了一个功能强大的ORM(对象关系映射)系统,使得开发者可以使用Python代码来操作数据库,而无需编写复杂的SQL语句。以下是Django数据库操作的一些基本概念和方法:

模型定义

在Django中,模型是对数据库表的抽象。每个模型都是一个Python类,继承自django.db.models.Model。模型中的每个属性都对应数据库表中的一个字段。

python 复制代码
from django.db import models

class Blog(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    pub_date = models.DateTimeField(auto_now_add=True)

数据库迁移

当你定义或修改了模型后,需要创建迁移文件,并将这些变更应用到数据库中。

  • 创建迁移文件:

    python manage.py makemigrations
    
  • 应用迁移到数据库:

    python manage.py migrate
    

CRUD操作

  • 创建 :创建一个新的记录。

    python 复制代码
    blog = Blog(title='My first blog', content='This is my first blog post.')
    blog.save()
  • 读取 :查询数据库中的记录。

    python 复制代码
    blogs = Blog.objects.all()  # 获取所有记录
    blog = Blog.objects.get(id=1)  # 获取特定记录
  • 更新 :修改已存在的记录。

    python 复制代码
    blog = Blog.objects.get(id=1)
    blog.title = 'My updated blog'
    blog.save()
  • 删除 :删除记录。

    python 复制代码
    blog = Blog.objects.get(id=1)
    blog.delete()

查询集(QuerySet)

QuerySet是Django ORM返回的一种数据结构,用于表示数据库查询的结果集。它支持链式调用,可以进行过滤、排序、限制等操作。

  • 过滤:

    python 复制代码
    blogs = Blog.objects.filter(title__contains='Django')
  • 排除:

    python 复制代码
    blogs = Blog.objects.exclude(is_published=False)
  • 排序:

    python 复制代码
    blogs = Blog.objects.order_by('pub_date')
  • 限制:

    python 复制代码
    blogs = Blog.objects.all()[:10]  # 获取前10条记录

复杂查询

Django ORM支持更复杂的查询操作,如关联查询、聚合查询等。

  • 关联查询:

    python 复制代码
    from django.db.models import Count
    author_count = Author.objects.annotate(book_count=Count('book')).filter(book_count__gt=1)
  • 聚合查询:

    python 复制代码
    from django.db.models import Avg
    average_book_count = Author.objects.aggregate(avg_books=Avg('book__count'))

使用原生SQL

虽然Django ORM非常强大,但在某些情况下,你可能需要执行原生SQL语句。

  • 使用raw()方法:

    python 复制代码
    blogs = Blog.objects.raw('SELECT * FROM myapp_blog WHERE title LIKE "%Django%"')
  • 使用cursor()方法:

    python 复制代码
    from django.db import connection
    with connection.cursor() as cursor:
        cursor.execute('SELECT * FROM myapp_blog WHERE title LIKE %s', ['%Django%'])
        blogs = cursor.fetchall()

注意事项

  • 尽量使用Django ORM提供的抽象方法来操作数据库,这样可以保证代码的可读性和数据库的兼容性。
  • 当使用原生SQL时,需要特别注意SQL注入的风险。
  • 在进行数据库操作时,应该注意异常处理,避免因为数据库操作导致程序崩溃。

以上是Django数据库操作的一些基本概念和方法,更多详细信息可以参考Django的官方文档。

相关推荐
bug菌¹30 分钟前
滚雪球学Oracle[4.2讲]:PL/SQL基础语法
数据库·oracle
逸巽散人40 分钟前
SQL基础教程
数据库·sql·oracle
月空MoonSky1 小时前
Oracle中TRUNC()函数详解
数据库·sql·oracle
momo小菜pa1 小时前
【MySQL 06】表的增删查改
数据库·mysql
Marst Code2 小时前
(Django)初步使用
后端·python·django
编程老船长2 小时前
第26章 Java操作Mongodb实现数据持久化
数据库·后端·mongodb
全栈师3 小时前
SQL Server中关于个性化需求批量删除表的做法
数据库·oracle
Data 3173 小时前
Hive数仓操作(十七)
大数据·数据库·数据仓库·hive·hadoop
BergerLee4 小时前
对不经常变动的数据集合添加Redis缓存
数据库·redis·缓存