Django项目的ORM操作之--数据模型类创建
在django项目中,其自带了ORM(Object Relation Mapping)对象关系映射框架,我们在django项目下app的models模块下对类进行操作,通过ORM会将我们对类的操作转化为具体的数据库sql语句,继而实现对数据库的操作。
1. 数据模型类的简单创建:
在django项目下的app的models模块下:
注意:实现orm映射的前提是创建的类必须继承自django.db包下的models模块的Model类。
# 1.导入模块
from django.db import models
# 2.创建类,继承 --> 对应数据库操作是创建表,表名字为“app名+类名”, 名字自动全部转换为小写;
# sql语句: create table book_app_bookinfo(字段信息);
class BookInfo(models.Model):
pass
'''
也可通过元选项自定义在数据库中创建的表名,意义不大。
class Meta:
db_table = 'my_tablename'
'''
# 3.设计好了数据模型的类,即相当于创建好了表。但是我们发现上面这张表设计的时候并没有设计表的字段,这显然是不对的,下面进行字段的设计
class BookInfo(moels.Model):
# 设计字段名为bname, 约束字段类型为char,最大长度为20
bname = models.CharField(max_length=20)
bisDelete = models.BooleanField(default=false) # 逻辑删除,默认false
# 4.模型类已经完成,再将models模块的内容进行迁移即可执行ORM转换的sql语句,对数据库进行对应操作
在命令行下,进入当前django项目所在的(虚拟)环境,执行以下:
$ django-admin mkmigrations # 生产迁移文件(在django项目的app目录下的migrations目录下可看到生产了对应的迁移文件)
$ django-admin migrate # 执行迁移(即执行了对应的sql语句)
查看数据库,可以看到当前的数据库中新增了一张表book_app_bookinfo,主键id我们并没有设计,会自动给我们设计好。
2.数据模型类的映射关系:
app名:book_app
类名:BookInfo -->表名:book_app_bookinfo
类属性创建时的方法:CharField/BooleanField -->字段属性: char/bool
方法的参数选项:max_length/default -->字段属性的约束选项
[字段名] = models.[字段属性]([属性约束选项])
3.常用字段属性:
AutoField -->自动增长的IntegerField,通常不指定,django会自动创建,auto_increment
CharField -->字符串类型,必须有(max_length=[xx])参数
BooleanField -->布尔类型,不能为空(default=[ture/false])
DateField -->日期类型,参数:auto_now:自动设置为最后一次修改的时间戳 auto_now_add:自动设置为第一次创建时的时间戳
DateTimeField/TimeField -->日期类型,参数同DateField
SamllIntegerField -->整数类型,对应tinyint/smallint/int/bigint
Decimal -->小数类型,必须指定整数位和小数位(例: (max_digits=None,decimal_places=None))
BinaryField -->二进制类型
FloatField -->浮点类型
4.常用字段属性选项:
primary_key -->默认为False,True表示为主键,一般AutoField使用
null -->默认为False,True表示该字段可以为空(添加数据时该字段可以不设置)
blank -->默认为False,True表示添加数据时该字段的值可以为空值
default -->设置默认值
max_length -->最大长度
Django项目的ORM操作之--数据模型类创建的更多相关文章
- Django项目的ORM操作之--模型类数据查询
1.查询基本格式及理解: 类名.objects.[查询条件] 例如我们要查询数据库中一张表(bookinfo)的所有数据,sql语句为:select * from bookinfo, 对应模型类的操作 ...
- Django学习之ORM操作
一.一般操作 二.必知必会13条 返回QuerySet对象的方法有 特殊的QuerySet 返回具体对象的 返回布尔值的方法有 返回数字的方法 三.单表查询之神奇的双下划线 四.ForeignKey操 ...
- Django专题之ORM操作2
Django ORM操作 目录 一般操作 看专业的官网文档,做专业的程序员! 回到顶部 必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs ...
- Python/Django(CBV/FBV/ORM操作)
Python/Django(CBV/FBV/ORM操作) CBV:url对应的类(模式) ##====================================CBV操作============ ...
- Django - 表与ORM操作
Django - 表与ORM操作 一. 模板语言 模板中也有自己的语言, 该语言可以实现数据展示 - {{ 变量 }} - 循环 {% for i in all_publisher %} {{ for ...
- 跨过Nginx上基于uWSGI部署Django项目的坑
先说说他们的关系,Nginx和uWSGI都是Web服务器,Nginx负责静态内容,uWSGI负责Python这样的动态内容,二者配合共同提供Web服务以实现提高效率和负载均衡等目的.uWSGI实现了多 ...
- 初学Django基础02 ORM操作
django的ORM操作 之前我们知道了models.py这个文件,这个文件是用来读取数据结构的文件,每次操作数据时都走这个模块 常用字段 AutoField int自增列,必须填入参数 primar ...
- Django 模型层 ORM 操作
运行环境 1. Django:2.1.3 version 2. PyMysql: 0.9.3 version 3. pip :19.0.3 version 4. python : 3.7 versio ...
- docker笔记(3) ------Django项目的docker部署
2019-01-12 14:23:18 django容器连接到mysql_server容器分析:原myblog项目使用sqlit3数据库,使用mysql容器前需要在django中加入pymysql ...
随机推荐
- Linux下mysql允许远程连接怎么设置
1.root用户登录到mysql数据库代码示例:/usr/local/mysql/bin/mysql -u root -p (输入密码进入mysql)2.进入mysql,输入:代码示例:use mys ...
- GRUB2 分析 (三)
接上一篇 从地址0x8200开始的是lzma_decompress.img.这是由startup_raw.S编译生成的.这个文件稍微复杂点.首先一开始就是个跳转指令: ljmp $0, $ABS(LO ...
- Session管理之超时设置和强制下线
关于Session,在Java Web开发中,为我们提供了很多方便,Session是由浏览器和服务器之间维护的.好吧,闲话不多说,下面让我们一步一步来实现它们. (一)首先来说下Session超时时间 ...
- linux 分区格式化
要对一个u盘进行分区 windows上直接格式化就行了,但是我的u盘 由于之前做成的系统把u盘分成三个分区,windows只能格式化第一个分区其他两个分区只能看着,理论上windows上也有dd之类的 ...
- goquery常用语法
Find 查找获取当前匹配的每个元素的后代Eq 选择第几个Attr 获取对应的标签属性AttrOr 获取对应的标签属性.这个可以设置第二个参数.获取的默认值 如果获取不到默认调用对应默认值Each 遍 ...
- 20145324 《Java程序设计》第9周学习总结
20145324 <Java程序设计>第9周学习总结 教材学习内容总结 第十六章 1.JDBC是java联机数据库的标准规范.它定义了一组标准类与接口,标准API中的接口会有数据库厂商操作 ...
- 【前端】vue.js实现输入框绑定
vue.js实现输入框绑定 实现效果如下: 实现代码及注释 <!DOCTYPE html> <html> <head> <title>vue.js数据动 ...
- 如何使用curl进行网页授权
答:使用curl的-u选项,使用方法如下 curl -u username URL (会提示输入密码)
- SaltStack应用grains和jinja模板-第四篇
目标需求 1.使用jinja模板让apache配置监听本地ip地址 2.了解grains的基本使用方法 说明:实验环境是在前面的第二篇和第三篇基础上完成 实现步骤 使用grains获取ip地址信息 使 ...
- PLMN和PSTN
一.PLMNPLMN公众陆地移动电话网(PLMN) public land mobile network 由政府或它所批准的经营者,为公众提供陆地移动通信业务目的而建立和经营的网路.该网路必须与公众交 ...