在Django中可以建立自己的模型Model,这里对应Java里的实体类,跟数据库表是对应的。其中用到了django.db模块中的models。如下图所示:  

 mysite/news/models.py
from django.db import models class Reporter(models.Model):
full_name = models.CharField(max_length=70) def __str__(self): # __unicode__ on Python 2
return self.full_name class Article(models.Model):
pub_date = models.DateField()
headline = models.CharField(max_length=200)
content = models.TextField()
reporter = models.ForeignKey(Reporter) def __str__(self): # __unicode__ on Python 2
return self.headline

  这里建立了两个类,一个是Reporter,一个是Article。每个类都还定义了一个函数(Python中的函数相当于Java或者JavaScript中的方法,Python用关键字def对函数进行定义,JavaScript用function定义而已) "__str__" ,注意这里函数名字,是前后各有两个下划线,其作用就是返回这个类的字符串描述,可以理解成相当于java中的toString方法。

  Reporter有一个字段交full_name,类型是CharField(最大长度是70),这里我理解就是告诉程序他是一个字符串类型的数据,最大长度是70,方便根据此映射数据库。

  Article中定义了pub_date,他是一个时间类型的数据,headline是一个字符串类型的数据,content是一个text类型的数据,这里还给Article定义了一个外键ForeignKey为Reporter,这样在用程序自动生成数据库表的时候就会自动建立外键关联了。

  以上为Python对实体类的定义。然后通过执行Python命令就可以轻松创建数据库表了。

  自动创建数据库表的Python命令是:Python manage.py migrate  。其中migrate是迁移的意思,可以理解成将Python类迁移、映射到数据库中,Python会自动给表加上主键,名称是id。

  一旦建立了表,那么Python就可以通过Python中定义的类操作这些数据库中的表数据了。如下:

  

 # 导入刚才新建模块中的类Reporter和Article
>>> from news.models import Reporter, Article # 查询所有的Reporter,显示为空
>>> Reporter.objects.all()
[] # 建立一个新的Reporter,全称叫John Smith
>>> r = Reporter(full_name='John Smith') # 保存这个对象到数据库,只需要调用save函数即可。
>>> r.save() # 通过.id即可以获取到刚才保存的Reporter数据的id
>>> r.id
1 #再次查询数据库中的Reporter,则刚才新插入的Reporter会显示出来,可以看出来这里显示的内容即是在类里面__str__定义返回的内容
>>> Reporter.objects.all()
[<Reporter: John Smith>] # 通过.属性名称既可以获取属性名
>>> r.full_name
'John Smith' # django还提供了丰富的API来查询过滤数据,
>>> Reporter.objects.get(id=1)
<Reporter: John Smith>
#查询full_name以'John'开头的数据
>>> Reporter.objects.get(full_name__startswith='John')
<Reporter: John Smith>
  #传full_name中包含'mith'的数据
>>> Reporter.objects.get(full_name__contains='mith')
<Reporter: John Smith>
  #如果查询不到数据,则会报查询不到的异常。这个应该是可以通过设定来防止报错的?
>>> Reporter.objects.get(id=2)
Traceback (most recent call last):
...
DoesNotExist: Reporter matching query does not exist. # 建立一个新的Article
>>> from datetime import date
>>> a = Article(pub_date=date.today(), headline='Django is cool',
... content='Yeah.', reporter=r)
>>> a.save() # Now the article is in the database.
>>> Article.objects.all()
[<Article: Django is cool>] # Article对象可以通过api获取其关联的Reporter对象的数据
>>> r = a.reporter
>>> r.full_name
'John Smith' # 反之亦然,通过Reporter对象可以获取所有的Article对象,通过对象.关联对象_set.all()获取
>>> r.article_set.all()
[<Article: Django is cool>] # The API follows relationships as far as you need, performing efficient
# JOINs for you behind the scenes.
# This finds all articles by a reporter whose name starts with "John".
  # Article还可以通过过滤其所属Reporter的相关信息来查询自己,如下通过reporter__reporter中的属性__startswith='John'
  # 确实好强大  
>>> Article.objects.filter(reporter__full_name__startswith='John')
[<Article: Django is cool>] # Change an object by altering its attributes and calling save().
# 改变Reporter中full_name的值
>>> r.full_name = 'Billy Goat'
>>> r.save() # Delete an object with delete().
# 删除Reporter
>>> r.delete()
												

Django学习(三) Django模型创建以及操作的更多相关文章

  1. Django学习手册 - ORM 数据创建/表操作 汇总

    ORM 查询的数据类型: QuerySet与惰性机制(可以看作是一个列表) 所谓惰性机制:表名.objects.all()或者.filter()等都只是返回了一个QuerySet(查询结果集对象),它 ...

  2. Django学习之django自带的contentType表 GenericRelation GenericForeignKey

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  3. day 94 Django学习之django自带的contentType表

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  4. day 93 Django学习之django自带的contentType表

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  5. day 91 Django学习之django自带的contentType表

      Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net ...

  6. Django学习之django自带的contentType表

    Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/aar ...

  7. Django(三) 模型:ORM框架、定义模型类并创建一个对应的数据库、配置Mysql数据库

    一.模型概述 https://docs.djangoproject.com/zh-hans/3.0/intro/tutorial02/ https://www.runoob.com/django/dj ...

  8. Django 学习笔记之模型高级用法

    目录 1 复杂的字段类型 1.1 整数类型的区别 1.2 自增类型的区别 1.3 时间类型 1.4 FilePathField 1.5 FileField 1.6 ImageField 2 关系字段 ...

  9. django学习-10.django连接mysql数据库和创建数据表

    1.django模型 Django对各种数据库提供了很好的支持,包括:PostgreSQL.MySQL.SQLite.Oracle. Django为这些数据库提供了统一的调用API. 我们可以根据自己 ...

随机推荐

  1. [Head First Python]6. 定制数据对象:打包代码与数据

    相同功能,演进实现 数据文件 sarah2.txt sarah Sweeney,2002-6-17,2:58,2.58,2:39,2-25,2-55,2:54,2.18,2:55,2:55 1- 返回 ...

  2. py函数递归

    1.从前有座山,山中有座庙,庙里有一个老和尚在讲故事... 2.递归:程序调用自身. 3.形式:在函数定义有直接或间接调用自身. 例如:阶乘: n!= 1 x 2 x 3 x ... x n; 从后身 ...

  3. 【2】开发环境的搭建,Ubuntu14.04

    这里使用的是Ubuntu14.04 Unity 更新源 首先,将更新源更换为国内更新源,我这里使用的是网易的更新源 sudo gedit /etc/apt/sources.list deb http: ...

  4. Mysql 6.7.7 + EntityFramework 5.0 Code First 不能 Update-Database 问题的解决

    1.修改 Migrations/Configuration.cs 文件 namespace DataModel.Migrations { using System; using System.Data ...

  5. ES6新特性-------解构、参数、模块和记号(续)

    六.解构 解构提供了一个方便的地从对象或数组中提取数据的方法,请看下面的例子: //ES6 let [x,y]=[1,2];//x=1,y=2 //ES5 var arr=[1,2]; var x=a ...

  6. python----特性003

    python特性003:计算特性 #!/usr/local/bin/python3.5 class MyNumber(object): def __init__(self,number): self. ...

  7. SQL Server索引 - 索引(物化)视图 <第九篇>

    一.索引视图基本概念 索引视图实际上是一种将一组唯一值“物化”为群集索引形式的视图,所为物化就是几乎和表一样,其数据也是会存储一份的(会占用硬盘空间,但是查询速度快,例如可以将count(),sum( ...

  8. Android 圆形按钮实现

    项目中用到的圆形按钮,做个半天,用sharp形式实现,样式代码如下: <Button android:id="@+id/btn_5" android:layout_width ...

  9. java中classPath和Xpath问题

    java中classPath和Xpath问题 今天遇到一个问题想获取classpath对应的目录,开始还以为java源代码可以像spring配置文件.xml中一样通过classpath:来获取对应的路 ...

  10. MSSQL WITH (NOLOCK) 脏读

    缺点: 1.会产生脏读 2.只适用与select查询语句 优点: 1.有些文件说,加了WITH (NOLOCK)的SQL查询效率可以增加33%. 2.可以用于inner join 语句 脏读: 一个用 ...