一、Django 连接 MySQL


修改 settings.py 文件

# 默认用的是sqlite3
# Database
# https://docs.djangoproject.com/en/4.1/ref/settings/#databases # DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': BASE_DIR / 'db.sqlite3',
# }
# } # 配置文件中配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'xyz',
'USER':'root',
'PASSWORD':'root',
'HOST':'114.116.30.138',
'PORT':3306,
'CHARSET':'utf8'
}
}

二、导入 pymysql


django默认用的是 mysqldb 模块链接 MySQL,但是该模块的兼容性不好 需要手动改为用pymysql 连接。

在项目名下的init 或者任意的应用名下的init 文件中书写以下代码都可以

import pymysql
pymysql.install_as_MySQLdb()

安装 pymysql

pip3 install pymysql

三、Django ORM


ORM 是对象关系映射(英语:Object Relational Mapping,简称 ORM),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。

ORM 的由来:面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两套理论存在显著的区别。为了解决这个不匹配的现象,对象关系映射技术应运而生。

1 app 应用下面的 models.py 文件中书写一个类

from django.db import models

# Create your models here.

# CharField    必须要指定 max_length 参数不指定会直接报错
# verbose_name 该参数是所有字段都有,用来对字段的解释 class User(models.Model):
# id int primary_key auto_increment
id = models.AutoField(primary_key=True,verbose_name='主键')
# username varchar(32)
username = models.CharField(max_length=32,verbose_name='用户名')
password = models.CharField(max_length=64,verbose_name='密码')
age = models.IntegerField(verbose_name='年龄')

2 数据库迁移命令 将操作记录到(migrations文件夹)中

python manage.py makemigrations

3 将操作真正的同步到数据库中

python manage.py migrate

只要修改了 models.py 中跟数据库相关的代码 就必须重新执行上述的两条命令

 4 生成许多表,而 app_user 是自己定义的

四、 id 字段


由于一张表中必须要有一个主键字段 并且一般情况下都叫 id字段。

所以ORM 当你不定义主键字段的时候 ORM 会自动帮你创建一个名为 id主键字段。

也就意味着 后续我们在创建模型表的时候,如果主键字段名没有额外的叫法,那么主键字段可以省略不写。

五、字段的增删改查


字段的增加
 
1 可以在终端内直接给出默认值

2 该字段可以为空(null=True)
info = models.CharField(max_length=32, verbose_name='个人简介', null=True)
3 直接给字段设置默认值(default='py')

hobby = models.CharField(max_length=32, verbose_name='兴趣爱好', default='py')

字段的修改

  • 直接修改代码,然后执行数据库迁移的两条命令即可。
字段的删除
  • 直接注释对应的字段然后执行数据库迁移的两条命令即可!执行完毕之后字段对应的数据也都没有了。
  • 注意:在操作 models.py 的时候一定要细心,千万不要注释一些字段,执行迁移命令之前最好先检查一下自己写的代码。
增加email字段(终端内直接给出默认值)
 

最新文章

  1. Maven总结
  2. 1.NSNotification|远程通知|本地通知|激光推送
  3. Cracking-- 17.13 将二叉树转换成双向链表
  4. #8.10.16总结# 属性选择符 伪对象选择符 CSS的常用样式
  5. 去除项目中的SVN标记
  6. 线程入门之实现Runnable接口和继承Thread类
  7. HDU 4489 The King’s Ups and Downs (DP+数学计数)
  8. IOS多线程知识总结/队列概念/GCD/串行/并行/同步/异步
  9. IE8 placeholder兼容+Password兼容
  10. Struts2 学习第一步准备工作
  11. Openjudge-计算概论(A)-数组顺序逆放
  12. Learn c for the Second day
  13. Django配置mysql
  14. intelj idea 创建聚合项目(典型web项目,包括子项目util、dao、service)
  15. uCos-II中任务的同步与通信
  16. Linux 安装 powershell
  17. css3 属性
  18. 51nod 1162 质因子分解
  19. hive使用python脚本导致java.io.IOException: Broken pipe异常退出
  20. C语言笔记变量与数据类型

热门文章

  1. Contest
  2. PTA(BasicLevel)-1031 查验身份证
  3. 基于MATLAB静态目标分割的药板胶囊检测
  4. 准备java编程软件与第一个java程序
  5. PostgreSQL的查询技巧: 零除, GENERATED STORED, COUNT DISTINCT, JOIN和数组LIKE
  6. docker安装Nessus
  7. Markdown 的基本使用
  8. 参数化设计(多次调用同一子模块,critical warning,引脚constraint sources)
  9. django项目、vue项目部署云服务器
  10. EFCore高级Saas系统下一个DbContext如何支持多数据库迁移