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()方法。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容

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