Django——数据库配置和数据模型创建

本文详细介绍了如何在Django项目中配置数据库,包括MySQL和SQLite3,并演示了数据模型的创建过程,如字段类型定义及模型注册。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库配置

settings.py
DATABASES = {
    #第一个数据库
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'blog',
        'USER': 'root',
        'PASSWORD': '******',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    },
    
    #第二个数据库
    'MyDjango': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'sqlite3'),
    },
}

数据模型创建

Django的数据模型以类包装,具体格式为:

from django.db import models

#class 模型类名称(models.Model)
class ModelName(models.Model)
    
    #数据模型 = 数据类型
    title = models.CharField(max_length=20)
    author = models.CharField(max_length=20, null=True)
    created_date = models.DateField(auto_now_add=True)
    update_date = models.DateField(auto_now=True)
    content = models.TextField()
    is_showed = models.BooleanField()
index/models.py
from django.db import models

# Create your models here.
class Article(models.Model):
    title = models.CharField("标题",max_length=20)
    author = models.CharField("作者", max_length=20, null=True)
    created_date = models.DateField("创建日期", auto_now_add=True)
    update_date = models.DateField("修改日期", auto_now=True)
    content = models.TextField("内容")
    is_showed = models.BooleanField("私密设置")

    #定义数据库中存储数据模型的表名称
    class Meta:
        db_table = "article"

    def __str__(self):
        return self.title

激活模型

  1. settings.py 中的INSTALLED_APPS列表中添加app
  2. 运行命令
python manage.py makemigrations index

其中index是app名称
3. 运行命令

python manage.py migrate

注册模型

为了便于管理数据模型,需要将数据注册到admin中。
如果没有创建admin账户,首先在终端运行指令:

python manage.py createsuperuser

然后根据提示输入相关信息即可创建一个超级用户
创建完成后进入app目录下的 admin.py

  1. 导入想要注册的数据模型
from .models import Article
  1. 进行注册操作
admin.site.register(Article)

至此注册完成,可以在后台对该数据模型进行管理
在这里插入图片描述

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在 IT 领域,文档格式转换是常见需求,尤其在处理多种文件类型时。本文将聚焦于利用 Java 技术栈,尤其是 Apache POI iTextPDF 库,实现 doc、xls(涵盖 Excel 2003 及 Excel 2007+)以及 txt、图片等格式文件向 PDF 的转换,并实现在线浏览功能。 先从 Apache POI 说起,它是一个强大的 Java 库,专注于处理 Microsoft Office 格式文件,比如 doc xls。Apache POI 提供了 HSSF XSSF 两个 API,其中 HSSF 用于读写老版本的 BIFF8 格式(Excel 97-2003),XSSF 则针对新的 XML 格式(Excel 2007+)。这两个 API 均具备读取写入工作表、单元格、公式、样式等功能。读取 Excel 文件时,可通过创建 HSSFWorkbook 或 XSSFWorkbook 对象来打开相应格式的文件,进而遍历工作簿中的每个 Sheet,获取行列数据。写入 Excel 文件时,创建新的 Workbook 对象,添加 Sheet、Row Cell,即可构建新 Excel 文件。 再看 iTextPDF,它是一个用于生成修改 PDF 文档的 Java 库,拥有丰富的 API。创建 PDF 文档时,借助 Document 对象,可定义页面尺寸、边距等属性来定制 PDF 外观。添加内容方面,可使用 Paragraph、List、Table 等元素将文本、列表表格加入 PDF,图片可通过 Image 类加载插入。iTextPDF 支持多种字体样式,可设置文本颜色、大小、样式等。此外,iTextPDF 的 TextRenderer 类能将 HTML、
### 使用 Django、MySQL Vue 构建有声图书网站的最佳实践 #### 项目初始化与环境配置 为了启动一个基于DjangoVue的有声图书网站,需先设置好开发环境。这包括但不限于安装Python解释器以及确保所有必要的Django依赖库已就绪[^3]。 对于数据库的选择,在此案例中选用了MySQL作为后端存储解决方案,并通过Navicat这类工具来进行管理维护工作。此外,还需注意版本兼容性问题;例如,文中提到使用了特定版本组合——Python 3.7.7搭配MySQL 5.7。 #### 后端开发 (Django) ##### 创建配置Django应用 一旦环境准备完毕,则可着手建立新的Django工程及其内部的应用程序组件。考虑到项目的特殊需求(即提供在线听书服务),应当定义相应的数据模型来表示书籍信息、章节详情等内容实体。这些都将被保存至预先设定好的MySQL实例之中。 ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=200) author = models.CharField(max_length=100) class Chapter(models.Model): book = models.ForeignKey(Book, on_delete=models.CASCADE) content_url = models.URLField() # 假设音频文件托管于外部CDN或云盘 ``` 上述代码片段展示了两个简单的ORM类映射关系,用于描述一本书籍与其所属各章节之间的关联形式。 ##### API接口设计 为了让前端能够顺利获取到所需的数据资源,必须精心规划RESTful风格的服务端点。借助`django-rest-framework`这样的第三方包可以帮助简化这一过程,从而使得开发者可以专注于业务逻辑本身而非底层通信细节。 #### 前端开发 (Vue.js) ##### 用户界面构建 在完成了基础架构之后,接下来就是打造直观易用的操作面板供访客浏览及收听电子读物之用了。这里推荐运用现代JavaScript框架之一—Vue.js 来完成这项任务。其声明式的语法糖特性极大地提高了编码效率的同时也降低了学习曲线[^4]。 利用HTML/CSS/JS编写静态页面元素,再配合Vue指令实现动态效果,比如加载进度条显示或是播放控制按钮等功能部件。与此同时,还可以考虑引入Element UI等UI库进一步美化整体外观样式。 ##### 客户端请求处理 最后一步便是让前后两端之间建立起有效的联系渠道。通常来说会采用AJAX异步调用来发起HTTP GET/POST 请求并与远端API进行交互。当然也可以探索WebSocket长连接机制以支持更加复杂的场景需求,不过对于本项目而言前者已经足够胜任了。 ```javascript axios.get('/api/books/') .then(response => { this.books = response.data; }) .catch(error => console.log(error)); ``` 这段脚本示范了怎样从服务器拉取最新发布的书籍列表并将结果显示给当前用户查看。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值