【记录】Django数据库的基础操作

数据库连接

在Django中使用 mysqlclient 这个包用于数据库的连接,切换至 Django环境中直接

pip install mysqlclient

安装此包

1 数据库连接配置

在项目目录下的setting.py中配置

复制代码
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mini',#数据库名
        'USER': 'ro',#用户名
        'HOST': 'localhost',#服务器IP
        'PORT': '3306',33端口号
        'PASSWORD': '1456',#密码
        'OPTIONS': {'charset': 'utf8mb4'},
    }
}

2 定义Models

注意书写过程中需要保证缩进,不要在某一行后加 逗号等标点符号

复制代码
from django.db import models

# Create your models here.
#创建数据库中的表 
#数据库需要先创建好 因为 mysqlclient 这个包只能创建表 不能创建数据库
#表名:ai_imgdetail
class ImgDetail(models.Model):
    #图片的id
    imgId = models.BigIntegerField()
    #上传时间
    timeStamp = models.DateTimeField()
    #校验时间
    validateTime = models.DateTimeField()
    #经度
    longitude = models.FloatField()
    longitudeRef = models.CharField(max_length=2)
    #纬度
    latitude = models.FloatField()
    latitudeRef = models.CharField(max_length=2)
    #海拔
    altitude = models.FloatField()
    altitudeRef = models.CharField(max_length=32)

3 运行

切换至项目根目录下,打开命令行,运行

复制代码
python .\manage.py makemigrations

此命令后,会在项目根目录下生成migratons文件夹

然后运行表生成命令

复制代码
 python .\manage.py migrate       

上述命令结束后,数据库中会生成创建好的数据表,但是会包含很多其他的表:

这个主要是在 Django的根目录下(setting.py)文件中包含下面的内容

如果上述命令在数据库中形成的表不对,则需要将 app文件夹中的 001_initial.py删除,重新运行上述两个命令。

4 表格或列删除

直接将models.py中的类注释,或某列名注释,再运行上述的命令即可。

5 已有表格添加新列

由于已有表格中有数据,当添加新列时,需要指定列的默认值。两种方法:

5.1 直接使用命令,会出现下面的提示
5.2 程序中直接添加
复制代码
altitude = models.FloatField(default=0.1)
或
altitude = models.FloatField(null=True,blank=True)
相关推荐
ζั͡山 ั͡有扶苏 ั͡✾3 小时前
从零搭建 Data-Juicer:一站式大模型数据预处理与可视化平台完整教程
python·data-juicer
SkylerHu3 小时前
tornado+gunicorn部署设置max_body_size
python·tornado·gunicorn
独行soc4 小时前
2025年渗透测试面试题总结-234(题目+回答)
网络·python·安全·web安全·渗透测试·1024程序员节·安全狮
木头左4 小时前
年化波动率匹配原则在ETF网格区间选择中的应用
python
清空mega4 小时前
从零开始搭建 flask 博客实验(3)
后端·python·flask
程序员小远5 小时前
7个常见的Jmeter压测问题
自动化测试·软件测试·python·测试工具·测试用例·压力测试·性能测试
红尘炼丹客5 小时前
《DeepSeek-OCR: Contexts Optical Compression》速览
人工智能·python·自然语言处理·ocr
☼←安于亥时→❦5 小时前
Playwright 安装与使用
python·playwright
大佬,救命!!!5 小时前
python实现象棋
开发语言·python·学习笔记·pygame·少儿编程·记录成长
棉猴5 小时前
《pygame中Sprite类实现多帧动画》注-通过多张序列帧显示动画2-2
开发语言·python·游戏·游戏程序·pygame