Python篇-Django框架详解(三)

TZ : 早睡早起,方能养生

一 : 科普一分钟

Ajax 不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术,用于web端的异步请求.
对于多表的ORM 该如何创建,删除,关联它们之间的关系,Django为我们提供了很多方法,让我们来揭开神秘的面纱吧.

配图.png

二 : ORM获取对象模式

  • 内部元素是对象 stu是一个 对像列表[obj1,obj2]
stu = models.Student.objects.all()
  • 内部元素都是字典 stu是一个字典列表 [ {'name':'tz','age':'26'} ]
stu  = models.Student.objects.all().values('name','age')
  • 内部元素都是元组 stu是一个元祖列表 [(雪芙,24),(容姿,23)]
stu = models.Business.Student.all().values_list('name','age')

三 : Ajax

Asynchronous Javascript And XML - > 异步 JavaScript 和 XML
通常用于web端与服务端的交互,可以直接在前台页面 JavaScript 调用后台页面的方法.
我们对某个标签进行绑定,然后进行Ajax请求, 可以看代码感觉一下 很像移动端安卓的Volley或者iOS的AFN网络请求框架.拿到后台返回的数据进行页面操作.

  • 页面进行JS操作
$('#TZajax').click(function(){
                $.ajax({
                    url: "/myajax",
                    type: 'POST',
                    //data: {'hostname': $('#host').val(), 'ip': $('#ip').val(), 'port': $('#port').val(), 'b_id': $('#sel').val()},
        #可以直接拿到表单对应的数据进行请求
                    data: $('#add_form').serialize(),
                    success: function(data){
                      #解码成json格式
                        var obj = JSON.parse(data);
                        if(obj.status){
                            #True 重新刷新页面
                            location.reload();
                        }else{
                            #弹出错误信息
                            $('#erro_msg').text(obj.error);
                        }
                    }
                })
            });
  • 服务端进行处理操作
def myajax(request):
    ret = {'status': True, 'error': None, 'data': 'hahaha'}
    try:
        h = request.POST.get('hostname')
        i = request.POST.get('ip')
        p = request.POST.get('port')
        b = request.POST.get('b_id')
        if h and len(h) > 5:
            models.Host.objects.create(hostname=h,
                                           ip=i,
                                           port=p,
                                           b_id=b)
        else:
            ret['status'] = False
            ret['error'] = "请求参数错误"
    except Exception as e:
        ret['status'] = False
        ret['error'] = '请求错误'
    return HttpResponse(json.dumps(ret))

四 : 多对多表操作

在A 表中的一行可以匹配 B 表中的多行,反之亦然。要创建这种关系,需要定义第三个表,称为[结合表],它的主键由 A 表和 B 表的外部键组成。例如,authorstitles 表具有多对多关系,这是由于这些表都与 titleauthors 表具有一对多关系。titleauthors 表的主键是 au_id 列(authors 表的主键)和 title_id 列(titles 表的主键)的组合。

  • 关系图
    关系
  • 自定义关系表
#表一
class Student(models.Model):
                nid = models.AutoField(primary_key=True)
                studentname = models.CharField(max_length=32,db_index=True)
                
            
#表二
class Course(models.Model):
                name = models.CharField(max_length=32)

#关系表
class StudentAndCourse(models.Model):
                hobj = models.ForeignKey(to='Student',to_field='nid')
                aobj = models.ForeignKey(to='Course',to_field='id')
  • 自动创建关系表
方式二:自动创建关系表

#表一
class Student(models.Model):
                nid = models.AutoField(primary_key=True)
                studentname = models.CharField(max_length=32,db_index=True)
    
#表二     
  class Course(models.Model):
                name = models.CharField(max_length=32)
                r = models.ManyToManyField("Student")
    #########           
            无法直接对第三张表进行操作,通过r 对关系表进行操作
            

            obj = Course.objects.get(id=1)
            obj.name
            
            # 第三张表操作 对id为1 的添加学生关系 
            obj.r.add(1)
            obj.r.add(2)
            obj.r.add(2,3,4)
                      #添加一组列表
            obj.r.add(*[1,2,3,4])
            
                        #移除关系
            obj.r.remove(1)
            obj.r.remove(2,4)
                      #移除一组关系
            obj.r.remove(*[1,2,3])
            
                    #清除所有关系
            obj.r.clear()
            
                  #重置关系
            obj.r.set([3,5,7])
            
            # 获取所有相关的对象“列表” QuerySet
            obj.r.all()

五 : 总结

我们可以给Ajax返回json接口, 应用于web端,也就是说,对于移动端,我们也可以用同样的方法写一个后台接口,让移动端调用,并且返回相应的数据.有移动端基础的同学,也可以尝试一下自己做一个接口,并且测试一下返回数据,多多尝试,下期再见.

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

推荐阅读更多精彩内容

  • 一. Java基础部分.................................................
    wy_sure阅读 3,810评论 0 11
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,623评论 18 399
  • 自定义控件学习https://github.com/GcsSloop/AndroidNote/tree/maste...
    wo叫天然呆阅读 9,009评论 10 140
  • “只要你还能睡觉,我们就会永远在一起。” 永远在一起 作者/曹畅洲 寺岛先生在一场空难中不幸遇难,他的女友幸子听闻...
    云间蓝阅读 669评论 1 4
  • 之前读过哈佛商学院营销学教授安妮塔·埃尔伯斯的(爆款)。她在文章中写道有关爆款策略很多的商业作用,比如:苹果手机、...
    松松劲柏阅读 183评论 0 0