Django 连接数据库 MySQL

一、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 连接数据库 MySQL

 

三、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 中跟数据库相关的代码 就必须重新执行上述的两条命令

 Django 连接数据库 MySQL

 

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

 Django 连接数据库 MySQL

四、 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字段(终端内直接给出默认值
 
Django 连接数据库 MySQL

 

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django 连接数据库 MySQL - Python技术站

(1)
上一篇 2023年4月2日 下午5:00
下一篇 2023年4月2日 下午5:00

相关文章

  • Django 之Auth模块

    一、Auth 模块是什么 Auth 模块是Django中自带的用户认证模块。 一个网站系统需要实现用户注册、用户登录、用户认证、注销、修改密码等功能,Django中内置了强大的认证系统-auth,默认使用 auth_user 表来存储用户的数据。 同时Django有一个后台管理系统(127.0.0.1:8000/admin),使用的用户名和密码也是这张数据表…

    2023年4月2日
    00
  • Django ORM 常用字段和参数

    一、models中的常用字段类型 字段类型 类型 说明 AutoField 自动增长的 IntegerField,通常不用指定,不指定时Django会自动创建属性名为 id 的自动增长属性。 BooleanField 布尔字段,值为True 或 False NullBooleanField 支持Null、True、False三种值 CharField 字符串…

    Python开发 2023年4月2日
    00
  • Python Web开发主流框架

    Web 开发是Python 语言应用领域的重要部分,也是工作岗位最多的领域。如果你对基于Python的Web 开发有兴趣,正打算使用Python 做Web 开发,或者已经是一个Web 开发者有工作需要,要做自动化运维、数据的图形化展示等,那么学习一门基于Python的Web 开发框架是必修课。 Python作为当前最火爆最热门,也是最主要的Web 开发语言之…

    2023年4月2日
    00
  • Django manage.py 命令详解

    manage.py 查看命令的作用的语句 C:\Users\Administrator> python manage.py help Type ‘manage.py help <subcommand>’ for help on a specific subcommand. Available subcommands: [auth] chan…

    Python开发 2023年4月2日
    00
  • Django 静态文件配置

    一、静态文件配置 在 settings.py 文件的最后添加 # settings.py # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/4.1/howto/static-files/ # STATIC SETTINGS STATIC_URL = ‘/s…

    2023年4月2日
    00
  • Django 聚合查询 分组查询 F与Q查询

    一、聚合查询 需要导入模块:from django.db.models import Max, Min, Sum, Count, Avg 关键语法:aggregate(聚合结果别名 = 聚合函数(参数)) 查询结果:使用聚合函数,从每一个组中获取结果:字典 注意点: 1 聚合函数必须在分组之后才能使用 2 没有分组,即默认整体就是一组 3 查询结果为 普通字…

    Python开发 2023年4月2日
    00
  • Django ORM 实现数据的单表 增删改查

    一、配置环境 1 Django 连接数据库(MySQL) DATABASES = { ‘default’: { ‘ENGINE’: ‘django.db.backends.mysql’, ‘NAME’: ‘xyz’, ‘USER’:’root’, ‘PASSWORD’:’root’, ‘HOST’:’IP地址’, ‘PORT’:3306, ‘CHARSET’…

    Python开发 2023年4月2日
    00
  • Django 聚合分组F与Q查询及choices

    一、聚合查询 需要导入模块:from django.db.models import Max, Min, Sum, Count, Avg 关键语法:aggregate(聚合结果别名 = 聚合函数(参数)) 查询结果:使用聚合函数,从每一个组中获取结果:字典 注意点: 1 聚合函数必须在分组之后才能使用 2 没有分组,即默认整体就是一组 3 查询结果为 普通字…

    Python开发 2023年4月2日
    00
合作推广
合作推广
分享本页
返回顶部