DjangoORM创建表结构以及生成数据库结构
1. ORM的两种
DB first: 创建表结构--根据表结构生成类-----根据类来操作数据库
Code first: 先写代码------再写类----执行命令(一个类生成一个表)当前主流的用法。Django的ORM属于code first的。
2. 本质
A-根据类自动创建数据库表
B-根据类对数据库表中的数据进行各种操作
3. -models.py #ORM,写指定的类,通过命令可以创建数据库结构。
3. 先在models.py中写类

2.到setting里面去设置,然后在数据库中生成表。
运行这句时python manage.py makemigrations ,Python会去找所有的models.py,帮咱们在数据库中生成这个表。
但是当有2个models.py的时候(分别在APP01,APP02里面),django就不知道该找哪个了。所以需要到setting里面去设置一下。
把app01加进去,这样Django就会去找app01下面的models,帮你生成数据库。

2. 指定目录为APP01,设置完以后,再去找的时候就没有问题了。执行python manage.py makemigrations
生成了一个名字为0001_initial.py的临时文件,里面记录着生成数据库表结构的一些数据。

3. 真正地生成数据库
执行:python manage.py migrate

生成了一个名为:db.sqlite3的数据库,默认情况下用的是sqlite

4. 这个db.sqlite3中包含了很多表,有一些是django自己用的,我们创建的表的名字叫app01_userinfo.

创建出来的表默认是sqlite3类型的,是因为在setting里面默认指定的就是用这个来创建的。

5.如果想把数据库改为用mysql,只需要在setting里面做相应的修改即可。用下面的把上面的sqlite替换即可。

5. models.py中的程序
from django.db import models # Create your models here. #django的ORM是code first
#app01_userinfo class UserInfo(models.Model):
# id列,自增,主键
#创建用户名列,字符串类型,可以指定长度
username=models.CharField(max_length=32)
password=models.CharField(max_length=64)
6.创建类的过程
step-1: 在models.py中创建一个类,这个类必须继承models.Model
from django.db import models
#django的ORM是code first
#app01_userinfo
class UserInfo(models.Model): #这个类必须继承models.Model
# id列,自增,主键
#创建用户名列,字符串类型,可以指定长度
username=models.CharField(max_length=32)
password=models.CharField(max_length=64)
step-2: 在project下的setting里面注册APP
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01',
]
step-3: 执行命令
python manage.py makemigrations
python manage.py migrate
step-4: 表结构创建完成,生成了一个名为:db.sqlite3的数据库,数据库中生成了一张名为app01_userinfo的表。
7.本节笔记
四,ORM操作:对象关系映射(Object Relational Mapping,简称ORM,)
是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换
#对应关系
models.tb.objects.filter(id__gt=1)
models.tb.objects.filter(id=1)
models.tb.objects.filter(id__lt=1) db first:先创建数据库的表结构,根据表结构生成类,然后根据类来操作数据库。
code first:先写代码,这个类生成一个表,那个类也生成一个表。(主流的) 1.在models.py中创建一个类,这个类必须继承models.Model
from django.db import models
#django的ORM是code first
#app01_userinfo class UserInfo(models.Model): #这个类必须继承models.Model
# id列,自增,主键
#创建用户名列,字符串类型,可以指定长度
username=models.CharField(max_length=32)
password=models.CharField(max_length=64) 2.注册APP INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01',
] 3,执行命令
python manage.py makemigrations
python manage.py migrate
DjangoORM创建表结构以及生成数据库结构的更多相关文章
- atitit.自动生成数据库结构脚本,或者更换数据库,基于hibernate4
atitit.自动生成数据库结构脚本,或者更换数据库,基于hibernate4 目前近况:: 更换数据库,但是是使用spring集成的. <!-- hibernate配置文件路径 --> ...
- 使用PowerDesigner创建表并导入到数据库
使用PowerDesigner创建表并导入到数据库 刚刚学习使用PowerDesigner进行数据库的创建,下面我就分享一下如何创建表并导入到数据库. 1.首先到网上下载一下PowerDesigner ...
- Navicat生成数据库结构同步SQL
作为一个苦逼的技术男,在做开发的时候经常会遇见程序版本升级,数据库结构变化.我们需要一个快捷的方式让客户尽快从旧版本数据库结构更新至新版本数据库结构.如果每做一次改动我们就记录一下当然是好事,但是万一 ...
- Qt 数据库创建表失败原因之数据库关键字
本人数据库新手,在创建表时出现问题,最后经查证,找出问题所在.下面的程序是部分节选,在创建数据库表的时候,起先使用的L24的CreateDB,经测试,一直输出 Create testResult Fa ...
- oracle创建表空间、添加数据库文件
创建表空间: create [undo|TEMPORARY]tablespace venn datafile '/opt/oracle/db01/app/oracle/oradata/OSSORCL/ ...
- ABP默认生成数据库结构
数据库设计文档 -- MyFirstABP 数据库设计文档 数据库名:MyFirstABP 序号 表名 说明 1 AbpFeatures 2 AbpEditions 3 AbpLanguage ...
- 记录—JPA生成数据库表
环境 springBoot+JPA+MySQL application-dev.yml 注意:配置中的blog数据库需要先创建,否则启动springBoot会报错 spring: #数据库连接配置 d ...
- Hibernate连接mysql数据库并自动创建表
天才第一步,雀氏纸尿裤,Hibernate第一步,连接数据库. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个 ...
- 使用laravel 的artisan快速创建表
参考:使用laravel 的artisan快速创建表 字段类型参考链接: 结构生成器 版本: Laravel 4.2 1. 创建migrate 文件 php artisan migrate:make ...
随机推荐
- cogs1341 永无乡
cogs1341 永无乡 打了一发替罪羊树. 鬼故事:替罪羊树去掉重构(变成裸的二叉排序树)依然跑得过= = 启发式合并.每次把小的里面所有东西往大的里面一丢,每个点最多被丢\(log_2n\)次(丢 ...
- Django模板层之templates
一 模版简介 你可能已经注意到我们在例子视图中返回文本的方式有点特别. 也就是说,HTML被直接硬编码在 Python代码之中. def current_datetime(request): now ...
- Flask 路由相关操作
URL Route URL 后接 / 作为目录级访问 URL 后不接 / 作为文件级访问 from flask import Flask app = Flask(__name__) @app.rout ...
- C、C++字符操作归总
1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度 ...
- selenium自动化之切换iframe
许多人在执行脚本的时候会发现,明明自己的元素路径没写错啊!怎么还是报元素未找到的异常呢?是的,没错,你可能是遇上iframe啦!下面将介绍关于iframe的相关操作. 例子:以163邮箱登录页面为例 ...
- vue2.0做移动端开发用到的相关插件和经验总结
最近一直在做移动端微信公众号项目的开发,也是我首次用vue来开发移动端项目,前期积累的移动端开发经验较少.经过这个项目的锻炼,加深了对vue相关知识点的理解和运用,同时,在项目中所涉及到的微信api( ...
- (转)ASP.NET Core 性能对比评测(ASP.NET,Python,Java,NodeJS)
转:https://www.cnblogs.com/savorboard/archive/2016/10/17/dotnet-benchmarks.html 前言 性能是我们日常生活中经常接触到的一个 ...
- 【第七章】MySQL数据库备份-物理备份
一.数据库备份 备份的目的: 备份: 能够防止由于机械故障以及人为误操作带来的数据丢失,例如将数据库文件保存在了其它地方. 冗余: 数据有多份冗余,但不等备份,只能防止机械故障还来的数据丢失,例如主备 ...
- 基于腾讯云CLB实现K8S v1.10.1集群高可用+负载均衡
概述: 最近对K8S非常感兴趣,同时对容器的管理等方面非常出色,是一款非常开源,强大的容器管理方案,最后经过1个月的本地实验,最终决定在腾讯云平台搭建属于我们的K8S集群管理平台~ 采购之后已经在本地 ...
- VPS挂机赚美刀详细介绍–Alexamaster操作流程
跟 vps 主机打交道时间长了,手里也渐渐积累了些闲置的 vps.让它们这么闲着吧,感觉有些浪费资源:用起来吧,暂时又没有好的项目.一直听说通过 vps挂机可以赚回主机成本,甚至可以盈利.正好这两天有 ...