django从入门到实战(四)——模型与数据库

1. 模型的定义与数据迁移

1.1 模型的定义

在 Django 中,模型是一个 Python 类,用于定义数据库中的数据结构。每个模型类对应数据库中的一张表,类的属性对应表中的字段。

示例

from django.db import models

class Blog(models.Model):
    title = models.CharField(max_length=200)  # 标题
    content = models.TextField()                # 内容
    created_at = models.DateTimeField(auto_now_add=True)  # 创建时间
    updated_at = models.DateTimeField(auto_now=True)      # 更新时间

    def __str__(self):
        return self.title

参数说明

  • models.Model: 所有模型类都需要继承自 models.Model
  • CharField: 用于存储字符串,max_length 是必需的参数。
  • TextField: 用于存储长文本。
  • DateTimeField: 用于存储日期和时间,auto_now_addauto_now 分别表示在创建和更新时自动设置当前时间。

1.2 数据迁移

数据迁移是将模型的变化应用到数据库的过程。Django 提供了命令行工具来管理迁移。

步骤

  1. 创建迁移文件
python manage.py makemigrations
  1. 应用迁移
python manage.py migrate

1.3 开发自己的 ORM 框架

开发自己的 ORM 框架涉及创建一个类来映射数据库表,并实现基本的 CRUD 操作。以下是一个简单的示例:

import sqlite3

class SimpleORM:
    def __init__(self, db_name):
        self.connection = sqlite3.connect(db_name)
        self.cursor = self.connection.cursor()

    def create_table(self, table_name, columns):
        columns_with_types = ', '.join([f"{name} {dtype}" for name, dtype in columns.items()])
        self.cursor.execute(f"CREATE TABLE IF NOT EXISTS {table_name} ({columns_with_types})")
        self.connection.commit()

    def insert(self, table_name, data):
        placeholders = ', '.join(['?'] * len(data))
        self.cursor.execute(f"INSERT INTO {table_name} VALUES ({placeholders})", tuple(data.values()))
        self.connection.commit()

    def fetch_all(self, table_name):
        self.cursor.execute(f"SELECT * FROM {table_name}")
        return self.cursor.fetchall()

    def close(self):
        self.connection.close()

参数说明

  • db_name: 数据库名称。
  • table_name: 表名。
  • columns: 字典,键为列名,值为数据类型。
  • data: 字典,键为列名,值为要插入的数据。

1.4 数据导入和导出

数据导入和导出可以通过 CSV 文件或其他格式进行。

导出示例

import csv

def export_to_csv(data, filename):
    with open(filename, mode='w', newline='') as file:
        writer = csv.writer(file)
        writer.writerows(data)

导入示例

def import_from_csv(filename):
    with open(filename, mode='r') as file:
        reader = csv.reader(file)
        return list(reader)

2. 数据表关系

在数据库中,表之间可以有不同的关系,主要包括:

  • 一对一关系:一个表中的一条记录对应另一个表中的一条记录。
  • 一对多关系:一个表中的一条记录可以对应另一个表中的多条记录。
  • 多对多关系:两个表中的记录可以相互对应多条记录。

示例

class Author(models.Model):
    name = models.CharField(max_length=100)

class Book(models.Model):
    title = models.CharField(max_length=200)
    author = models.ForeignKey(Author, on_delete=models.CASCADE)  # 一对多关系

3. 数据表操作

3.1 增删改查(CRUD)

增加
# 创建新博客
new_blog = Blog(title="My First Blog", content="This is the content.")
new_blog.save()
查询
# 查询所有博客
all_blogs = Blog.objects.all()

# 查询特定博客
specific_blog = Blog.objects.get(id=1)
更新
# 更新博客内容
specific_blog.content = "Updated content."
specific_blog.save()
删除
# 删除博客
specific_blog.delete()

3.2 多表查询

使用 Django 的 ORM 可以轻松进行多表查询。

# 查询某个作者的所有书籍
author_books = Book.objects.filter(author__name="Author Name")

4. 数据库与 SQL 语句

4.1 SQL 语句

SQL(结构化查询语言)用于与数据库交互。常用的 SQL 语句包括:

  • SELECT:查询数据。
  • INSERT:插入数据。
  • UPDATE:更新数据。
  • DELETE:删除数据。

4.2 数据库事务

事务是一组操作,要么全部成功,要么全部失败。Django 提供了事务管理的支持。

from django.db import transaction

with transaction.atomic():
    # 执行多个数据库操作
    blog = Blog(title="Transactional Blog", content="Content")
    blog.save()
    # 其他操作

5. Django 如何制作多个数据库的链接和使用

在 Django 中,可以在 settings.py 中配置多个数据库。

示例配置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / "db.sqlite3",
    },
    'secondary': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'mydatabase',
        'USER': 'myuser',
        'PASSWORD': 'mypassword',
        'HOST': 'localhost',
        'PORT': '5432',
    }
}

使用示例

from django.db import connections

with connections['secondary'].cursor() as cursor:
    cursor.execute("SELECT * FROM my_table")
    rows = cursor.fetchall()

6. 动态创建模型和数据表

动态创建模型和数据表可以通过 Django 的 type 函数和 create_model 方法实现。

示例

from django.db import models, connection

def create_dynamic_model(table_name):
    class Meta:
        db_table = table_name

    attrs = {'__module__': __name__, 'Meta': Meta}
    model = type(table_name.capitalize(), (models.Model,), attrs)
    return model

# 创建动态模型
DynamicModel = create_dynamic_model('dynamic_table')

7. MySQL 分表功能

MySQL 分表是将数据分散到多个表中,以提高性能和管理性。可以通过水平分表和垂直分表实现。

水平分表示例

假设我们有一个用户表,可以根据用户 ID 进行分表:

CREATE TABLE users_1 LIKE users;
CREATE TABLE users_2 LIKE users;

INSERT INTO users_1 SELECT * FROM users WHERE id % 2 = 0;
INSERT INTO users_2 SELECT * FROM users WHERE id % 2 = 1;

垂直分表示例

将用户表中的某些字段分到另一个表中:

CREATE TABLE user_profiles (
    user_id INT PRIMARY KEY,
    profile_picture VARCHAR(255),
    bio TEXT,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/918947.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LVGL-从入门到熟练使用

LVGL简介 LVGL( Light and Versatile Graphics Library )是一个轻量、多功能的开源图形库。 1、丰富且强大的模块化图形组件:按钮 、图表 、列表、滑动条、图片等 2、高级的图形引擎:动画、抗锯齿、透明度、平滑滚动、图层混合等…

从视频帧生成点云数据、使用PointNet++模型提取特征,并将特征保存下来的完整实现。

文件地址 https://github.com/yanx27/Pointnet_Pointnet2_pytorch?spm5176.28103460.0.0.21a95d27ollfze Pointnet_Pointnet2_pytorch\log\classification\pointnet2_ssg_wo_normals文件夹改名为Pointnet_Pointnet2_pytorch\log\classification\pointnet2_cls_ssg "E:…

时间序列关于可解释性值得关注的论文汇总-第2篇

前言 这是时序可解释性论文汇总的第二篇,第一篇见这里(后台回复:“论文合集”可直接获取整理的文章)。深度学习的可解释性研究一直是热门,而时间序列的可解释性同样非常重要。这是因为时序模型被大量应用到特定领域&a…

DataStream编程模型之数据源、数据转换、数据输出

Flink之DataStream数据源、数据转换、数据输出(scala) 0.前言–数据源 在进行数据转换之前,需要进行数据读取。 数据读取分为4大部分: (1)内置数据源; 又分为文件数据源; socket…

Java面试题2024-Java基础

Java基础 1、 Java语言有哪些特点 1、简单易学、有丰富的类库 2、面向对象(Java最重要的特性,让程序耦合度更低,内聚性更高) 3、与平台无关性(JVM是Java跨平台使用的根本) 4、可靠安全 5、支持多线程 2、…

数据结构(基本概念及顺序表——c语言实现)

基本概念: 1、引入 程序数据结构算法 数据: 数值数据:能够直接参加运算的数据(数值,字符) 非数值数据:不能够直接参加运算的数据(字符串、图片等) 数据即是信息的载…

使用爬虫获取的数据如何有效分析以优化店铺运营?

在数字化时代,数据已成为电商运营的核心。通过爬虫技术,我们可以从淘宝等电商平台获取大量数据,这些数据如果得到有效分析,将极大助力店铺运营的优化。本文将探讨如何使用爬虫技术获取数据,并利用数据分析来优化店铺运…

c++类对象练习

#include <iostream> #include <cstring>using namespace std;class mystring {char* buf; public:mystring(); //构造函数mystring(const char* str); //构造函数void show(); //输出函数void setmystr(const mystring str); //设置函数const char* getmystr() co…

后端:Spring AOP原理--动态代理

文章目录 1. Spring AOP底层原理2. 代理模式3. 静态代理4. 动态代理4.1 jdk 实现动态代理4.2 cglib 实现动态代理4.3 jdk、cglib动态代理两者的区别 1. Spring AOP底层原理 创建容器 new applicationContext()&#xff1b;Spring把所有的Bean进行创建&#xff0c;进行依赖注入…

微信小程序 最新获取用户头像以及用户名

一.在小程序改版为了安全起见 使用用户填写来获取头像以及用户名 二.代码实现 <view class"login_box"><!-- 头像 --><view class"avator_box"><button wx:if"{{ !userInfo.avatarUrl }}" class"avatorbtn" op…

【Linux】进程的状态详解

进程的状态详解 一、各种状态的概念二、运行状态的详细介绍三、阻塞状态详解四、挂起状态和阻塞状态的关系五、观察各种状态在linux中的表示1.运行态R2.睡眠态S3.暂停态T4.深度睡眠状态D5.僵尸状态Z6.孤儿进程 一、各种状态的概念 为了弄明白正在运行的进程是什么意思&#xf…

python高级之简单爬虫实现

一、前言 场景1&#xff1a;一个网络爬虫&#xff0c;顺序爬取一个网页花了一个小时&#xff0c;采用并发下载就减少到了20分钟。 场景2&#xff1a;一个应用软件优化前每次打开网页需要3秒&#xff0c;采用异步并发提升到了200毫秒。 假设一个工程的工作量为100&#xff0c…

web——upload-labs——第十关——.空格.绕过

审计源码 这次先删除文件名左右的空格&#xff0c;然后又删除了我们文件末尾的.&#xff0c;其次将我们上传的文件名转换为小写&#xff0c;删除文件末尾的::$DATA&#xff0c;最后又删除了文件名左右两侧的空格 根据他的逻辑&#xff0c;我们可以构造文件名phpinfo.php. .就是…

Percona XtraBackup备份docker版本mysql 5.7

my.cnf配置文件 [client] default_character_setutf8[mysqld] # 数据存储目录&#xff08;必须手动指定&#xff09; datadir/var/lib/mysql/data# 字符集 collation_server utf8_general_ci character_set_server utf8 # 二进制日志 server-id1 log_bin/var/log/mysql/binl…

JavaWeb之Vue

前言 这一节讲Vue 1. Vue概述 这些都是DOM的操作 原来模型和视图不能实现同步变化&#xff0c;但是Vue就可以了 2. 快速入门 1. 2. <script src"js/vue.js"></script><div id"app"> <!-- 准备一个input输入框,绑定一个模…

汽车资讯新篇章:Spring Boot技术启航

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…

Windows注册表基础学习

修改注册表让cmd ascii输出有颜色 reg add HKCU\Console /v VirtualTerminalLevel /t REG_DWORD /d 1 如何打开注册表编辑器 运行regedit 按下"Winr"组合键&#xff0c;在打开的"运行"对话框中输入"regedit"&#xff0c;单击"确定"…

C++ | Leetcode C++题解之第564题寻找最近的回文数

题目&#xff1a; 题解&#xff1a; using ULL unsigned long long;class Solution { public:vector<ULL> getCandidates(const string& n) {int len n.length();vector<ULL> candidates {(ULL)pow(10, len - 1) - 1,(ULL)pow(10, len) 1,};ULL selfPrefi…

Debezium-MySqlConnectorTask

文章目录 概要整体架构流程技术名词解释技术细节小结 概要 MySqlConnectorTask&#xff0c;用于读取MySQL的二进制日志并生成对应的数据变更事件 整体架构流程 技术名词解释 数据库模式&#xff08;Database Schema&#xff09; 数据库模式是指数据库中数据的组织结构和定义&…

【WPF】Prism学习(二)

Prism Commands 1.命令&#xff08;Commanding&#xff09; 1.1. ViewModel的作用&#xff1a; ViewModel不仅提供在视图中显示或编辑的数据&#xff0c;还可能定义一个或多个用户可以执行的动作或操作。这些用户可以通过用户界面&#xff08;UI&#xff09;执行的动作或操作…