Django - ORM操作

ORM:关系对象映射。Object Relation Mapping.
数据库与代码:

1)DB first
2)Code first

主流都是Code first.
SQLAlchemy 就是code first.
Django的ORM是code first.


1.创建类

1)根据类自动创建数据库表

app下models.py。

2)根据类对数据库表中的数据进行各种操作

2.迁移

1)在设置目录的settings.py的INSTALLED_APPS中添加APP模块.

2)python manage.py makemigrations 生成数据迁移临时文件
在所有app的migrations目录下回生成一个.py文件

3)python manage.py migrate 生成表
我们在SQLiteStudio中就可以看到。
默认情况下帮我们生成的表明就叫appname_classname,classname是小写。


图片.png

=======

增删改查

1.增

方法1

from app02 import models

def orm(request):
     models.UserInfo.objects.create(
         username='root',
         password = '123',
     )

方法二:

from app02 import models

def orm(request):
    
    obj = models.UserInfo(username='root', password='123')
    obj.save()

    return HttpResponse('orm-add')

方式3:

from app02 import models

def orm(request):
    
    dict = {'username':'root', 'password':'123'}

    obj = models.UserInfo(**dict)  # 注意添加星号
    obj.save()

    return HttpResponse('orm-add')

2.查

查所有对象

#urls.py
url(r'^orm_query/', views.orm_query),

# views.py
def orm_query(request):
    result = models.UserInfo.objects.all()
    for row in result:
        print (row.id, row.username, row.password)
    return HttpResponse('orm_query')

注意:这里查询的result是:
[obj(id, username, password), obj...]这样的。
Or这样查询:
只查id,username:

models.UserInfo.objects.all().values('id', 'username')

注意:这里的查询结果为:[{"id":xx, "username":xx, "password":xx}]

不管是传递的对象还是字典,在模板中取都是一样的取:

<h1>业务线列表(对象)</h1>
<ul>
    {% for row in v %}
    <li>{{ row.id }} - {{row.caption}} - {{row.code}}</li>
    {% endfor %}

</ul>

<h1>业务线列表(字典)</h1>
<ul>
    {% for row in v2 %}
    <li>{{ row.id }} - {{row.caption}} - {{row.code}}</li>
    {% endfor %}

</ul>

条件查询:

def orm_query(request):
    result = models.UserInfo.objects.filter(username='root1')
    for row in result:
        print (row.id, row.username, row.password)
    return HttpResponse('orm_query')

取出前5条数据:

models.Entry.objects.all()[:5]

3.删除

删除所有:

models.UserInfo.objects.all().delete()

条件删除:

models.UserInfo.objects.filter(username='liao').delete()

更新

更新所有:

models.UserInfo.objects.all().update(password='666')

条件更新:

models.UserInfo.objects.filter(id='1').update(username='liao1')

示例,判断登录:

def login(request):

    if request.method == 'GET':

        return render(request, 'app02/login.html')
    elif request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')

        result = models.UserInfo.objects.filter(username=username, password=password).first()  # 也可以count()判断个数

        if result:
            return redirect('/index/')
        else:
            return render(request, 'app02/login.html')

示例:

def userinfo(request):
    # QuerySet
    user_list = models.UserInfo.objects.all()
    print (user_list.query)
    return render(request, 'app02/userinfo.html', {'user_list':user_list})

user_list是QuerySet。QuerySet里面是一个一个的对象。 [obj,obj,obj...],对象中封装了每列的值。
user_list.query是查询语句。

SELECT "app02_userinfo"."id", "app02_userinfo"."username", "app02_userinfo"."password", "app02_userinfo"."liao" FROM "app02_userinfo"

示例:

def userinfo(request):

    # QuerySet
    user_list = models.UserInfo.objects.all()
    print (user_list.count())
    return render(request, 'app02/userinfo.html', {'user_list':user_list})

查询到的QuerySet,检查数量使用.count()方法。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 原文:https://my.oschina.net/liuyuantao/blog/751438 查询集API 参...
    阳光小镇少爷阅读 9,288评论 0 8
  • 22年12月更新:个人网站关停,如果仍旧对旧教程有兴趣参考 Github 的markdown内容[https://...
    tangyefei阅读 35,314评论 22 257
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,228评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,689评论 18 399
  • 1 创建一个博客应用 在本书中,你将学习如何创建完整的,可用于生产环境的Django项目。如果你还没有安装Djan...
    lakerszhy阅读 7,648评论 9 22

友情链接更多精彩内容