Django(根据Models中模型类反向生成数据库表)—— python篇

一、数据库的配置

1、 django默认支持 sqlite,mysql, oracle,postgresql数据库。

sqlite:django默认使用sqlite的数据库,默认自带sqlite的数据库驱动 , 引擎名称:django.db.backends.sqlite3

mysql:引擎名称:django.db.backends.mysql

2、创建数据库文件

首先需要在自己的mysql中创建数据库

2、SQlite配置

这个配置在创建Django项目的时候会默认配置好,如下:

python 复制代码
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

3、MySQL配置

这个就需要我们手动配置了,里面必须包括各项属性的设置,具体如下:

python 复制代码
DATABASES = {

    'default': {

        'ENGINE': 'django.db.backends.mysql',  # 引擎改为mysql

        'NAME': 'Django_ORM',    # 你的数据库名称

        'USER': 'root',   # 你的数据库用户名

        'PASSWORD': 'mysql', # 你的数据库密码

        'HOST': '127.0.0.1', # 你的数据库主机,留空默认为localhost

        'PORT': '3306', #你的数据库端口

    }
}

注意: 自己手动配置数据库,也需要手动修改数据库引擎。将mysql引擎放到项目Django_ORM的默认__init__文件下,也就是在__init__.py文件下加入以下代码:

python 复制代码
import pymysql
pymysql.install_as_MySQLdb()

二、Models数据表的创建

1、原本在mysql中创建表 应该如下

python 复制代码
creat table book(
    name varchar(20),
    price float(4,2),
)

2、在Django中需要用一个类来创建表 ,并且必须继承models.Model

python 复制代码
# 在Django的类中创建表:必须继承Model
class Book(models.Model):
    # 变量名name,类型为models.CharField字符型,最大长度是20
    name = models.CharField(max_length=20)
    # Floatfield为浮点型,IntegerField为整型,DateField为时间类型
    price = models.FloatField()
    put_date = models.DateField()

# 创建另一张表
class Author(models.Model):
    name = models.CharField(max_length=32)

3、执行创建

在配置好数据库、数据库引擎,并且创建完数据表后,就可以开始执行创建了

创建表的终端shell窗口执行命令:

python 复制代码
python manage.py makemigrations

生成数据库内容:

python 复制代码
python manage.py migrate

执行创建后,就可以在migrations文件夹看到创建的数据库文件了:

4、内容写入成功

这样数据库内容就成功写入了:

三、在Pycharm中显示

接下来就可以在pycharm中将数据库显示出来,并且能够可视化操作数据库

首先点击右侧的database:

然后点击左上角的"+"号,再Data Resource,再选MySQL:

设置好账户信息和数据库名称就可以了:

本次分享到此结束,感谢大家的阅读!

相关推荐
不羁。。3 分钟前
【撸靶笔记】第七关:GET - Dump into outfile - String
数据库·笔记·oracle
飞翔的佩奇1 小时前
【完整源码+数据集+部署教程】表盘指针检测系统源码和数据集:改进yolo11-CA-HSFPN
python·yolo·计算机视觉·数据集·yolo11·表盘指针检测
yangchanghua1112 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance2 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai2 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务2 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
搏博2 小时前
基于Python3.10.6与jieba库的中文分词模型接口在Windows Server 2022上的实现与部署教程
windows·python·自然语言处理·flask·中文分词
lxmyzzs3 小时前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
萧鼎4 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python