Django 表& 数据库 &缓存

一、表结构设计

1.1 abstract类

这个抽象类,可以在创建数据库表数据,跳过,不让程序创建。

from django.db import models

# 逻辑删除表
class ActiveBaseModel(models.Model):
    active = models.SmallIntegerField(verbose_name="状态", default=1, choices=((1, "激活"), (0, "删除"),))

    class Meta:
        abstract = True

# Administrator继承ActiveBaseModel,会自动创建一个active
class Administrator(ActiveBaseModel):
    """ 管理员表 """
    username = models.CharField(verbose_name="用户名", max_length=32, db_index=True)
    password = models.CharField(verbose_name="密码", max_length=64)
    mobile = models.CharField(verbose_name="手机号", max_length=11, db_index=True)
    create_date = models.DateTimeField(verbose_name="创建日期", auto_now_add=True)

1.2 自增和主键

默认:DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'

class Administrator(models.Model):
    """ 管理员表 """
    uid = models.AutoField(verbose_name="自增", primary_key=True)
    
    username = models.CharField(verbose_name="用户名", max_length=32, db_index=True)
    password = models.CharField(verbose_name="密码", max_length=64)
    mobile = models.CharField(verbose_name="手机号", max_length=11, db_index=True)
    create_date = models.DateTimeField(verbose_name="创建日期", auto_now_add=True)

1.3 物理删除 & 逻辑删除

物理删除:直接从数据库把整条记录删除。
有些时候需要保留一些数据,如果物理删除,则无法恢复。逻辑删除,可以看做多加一个字段,作为标记。

class Administrator(ActiveBaseModel):
    """ 管理员表 """
    username = models.CharField(verbose_name="用户名", max_length=32, db_index=True)
    password = models.CharField(verbose_name="密码", max_length=64)
    mobile = models.CharField(verbose_name="手机号", max_length=11, db_index=True)
    create_date = models.DateTimeField(verbose_name="创建日期", auto_now_add=True)
    active = models.SmallIntegerField(verbose_name="状态", default=1, choices=((1, "激活"), (0, "删除"),))

二、数据库连接

2.1 修改settings配置

自己选择使用的数据库引擎,这里选用mysql为例(前提是安装了mysql)
在这里插入图片描述
然后在注册app里加入自己的app
在这里插入图片描述

2.2 下载pymysql,并且配置

pip下载pymysql后,到app目录下的__init__.py文件,导入并配置pymysql
在这里插入图片描述

三、redis缓存 和 session

3.1 redis

同样,先安装redis,然后在安装 django-redis 库 pip install django-redis

redis 安装暂时不详细写,后面补。安装并配置redis.conf
启动redisredis-server redis.conf
ps:自己的加了密码,需要认证。 auth “qwe123”

与mysql一样,需要在settings配置

CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
            "CONNECTION_POOL_KWARGS": {"max_connections": 100},
            "PASSWORD": "qwe123",
            # 'MAX_ENTRIES': 300,  # 最大缓存个数(默认300)
            # 'CULL_FREQUENCY': 3,  # 缓存到达最大个数之后,剔除缓存个数的比例,即:1/CULL_FREQUENCY(默认3)
        }
    }
}

配置好后,尝试使用:

from django.shortcuts import HttpResponse
def login(request):
    from django_redis import get_redis_connection
    conn = get_redis_connection("default")
    conn.set("xx", "123123")
    c = conn.get("xx")
    print(c)
    return HttpResponse('login')

然后访问连接login,输出了c值,就算成功

3.2 session

############
# SESSIONS #
############
# Session存储在哪里?
# SESSION_ENGINE = "django.contrib.sessions.backends.db"

# 如果存储到文件中,文件的路径。
# SESSION_ENGINE = "django.contrib.sessions.backends.file"
# SESSION_FILE_PATH = None

# 存储到缓存
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"

可以选择不同session存储位置。将seesion配置存储到之前配置的缓存中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值