Django进阶

1.orm

1.1 基本操作

orm,关系对象映射。

类      --> SQL -->     表
对象    --> SQL -->     数据

特点:开发效率高、执行效率低( 程序写的垃圾SQL )。

编写ORM操作的步骤:

  • settings.py,连接数据库

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3',
            'NAME': BASE_DIR / 'db.sqlite3',
        }
    }
    
  • settings.py,注册app

    INSTALLED_APP = [
    	...
    	"app01.apps.App01Config"
    ]
    
  • 编写models.类

    class UserInfo(models.Model):
        ....
        .....
    
  • 执行命令

    python manage.py makemigrations    # 找到所有已注册的app中的models.py中的类读取 -> migrations配置
    python manage.py migrate           # 读取已注册的app下的migrations配置 -> SQL语句  -> 同步数据库
    

1.2 连接数据库

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'xxxxxxxx',  # 数据库名字
        'USER': 'root',
        'PASSWORD': 'root123',
        'HOST': '127.0.0.1',  # ip
        'PORT': 3306,
    }
}

项目连接MySQL:

  • 安装MySQL & 启动MySQL服务

  • 手动创建数据库

  • django的settings.py配置

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'xxxxxxxx',  # 数据库名字
            'USER': 'root',
            'PASSWORD': 'root123',
            'HOST': '127.0.0.1',  # ip
            'PORT': 3306,
        }
    }
    
  • 安装第三方组件

    • pymysql

      pip install pymysql
      
      项目根目录/项目名目录/__init__.py
      	import pymysql
      	pymysql.install_as_MySQLdb()
      
    • mysqlclient

      pip install mysqlclient
      
      电脑上先提前安装MySQL。
      

其他数据库:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'mydatabase',
        'USER': 'mydatabaseuser',
        'PASSWORD': 'mypassword',
        'HOST': '127.0.0.1',
        'PORT': 5432,
    }
}

# 需要 pip install psycopg2
DATABASES = {
	'default': {
        'ENGINE': 'django.db.backends.oracle',
        'NAME': "xxxx",  # 库名
        "USER": "xxxxx",  # 用户名
        "PASSWORD": "xxxxx",  # 密码
        "HOST": "127.0.0.1",  # ip
        "PORT": 1521,  # 端口
    }
}
# 需要 pip install cx-Oracle

1.3 连接池

django默认内置没有数据库连接池 。

pymysql   -> 操作数据库
DBUtils   -> 连接池

https://pypi.org/project/django-db-connection-pool/

pip install django-db-connection-pool
DATABASES = {
    "default": {
        'ENGINE': 'dj_db_conn_pool.backends.mysql',
        'NAME': 'day04',  # 数据库名字
        'USER': 'root',
        'PASSWORD': 'root123',
        'HOST': '127.0.0.1',  # ip
        'PORT': 3306,
        'POOL_OPTIONS': {
            'POOL_SIZE': 10,  # 最小
            'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。
            'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。
            'TIMEOUT':30, # 池中没有连接最多等待的时间。
        }
    }
}

注意:组件django-db-connection-pool不是特别厉害。拿了另外一个支持SQLAchemy数据库连接池的组件。

1.4 多数据库

django支持项目连接多个数据库。

DATABASES = {
    "default": {
        'ENGINE': 'dj_db_conn_pool.backends.mysql',
        'NAME': 'day05db',  # 数据库名字
        'USER': 'root',
        'PASSWORD': 'root123',
        'HOST': '127.0.0.1',  # ip
        'PORT': 3306,
        'POOL_OPTIONS': {
            'POOL_SIZE': 10,  # 最小
            'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。
            'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。
            'TIMEOUT': 30,  # 池中没有连接最多等待的时间。
        }
    },
    "bak": {
        'ENGINE': 'dj_db_conn_pool.backends.mysql',
        'NAME': 'day05bak',  # 数据库名字
        'USER': 'root',
        'PASSWORD': 'root123',
        'HOST': '127.0.0.1',  # ip
        'PORT': 3306,
        'POOL_OPTIONS': {
            'POOL_SIZE': 10,  # 最小
            'MAX_OVERFLOW': 10,  # 在最小的基础上,还可以增加10个,即:最大20个。
            'RECYCLE': 24 * 60 * 60,  # 连接可以被重复用多久,超过会重新创建,-1表示永久。
            'TIMEOUT': 30,  # 池中没有连接最多等待的时间。
        }
    },
}

1.4.1 读写分离

192.168.1.2       default master   [写]
                  组件
192.168.2.12      bak slave    [读]
  • 生成数据库表

    python manage.py makemigrations    # 找到所有已注册的app中的models.py中的类读取 -> migrations配置
    
    python manage.py migrate
    python manage.py migrate --database=default
    python manage.py migrate --database=bak
    
  • 后续再进行开发时

    models.UserInfo.objects.using("default").create(title="武沛齐")
    
    models.UserInfo.objects.using("bak").all()
    
  • 编写router类,简化【后续再进行开发时】

    class DemoRouter(object):
        
        def db_for_read(...):
            return "bak"
        
        def db_for_write(...):
            return "default"
    
    router = ["DemoRouter"]
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lhY2Qz9B-1691504274637)(assets/image-20220710104821310.png)]

1.4.2 分库(多个app ->多数据库)

100张表,50表-A数据库【app02】;50表-B数据库【app02】。

  • app01/models

    from django.db import models
    
    
    class UserInfo(models.Model):
        title = models.CharField(verbose_name="标题", max_length=32)
    
    
  • app02/models

    from django.db import models
    
    
    class Role(models.Model):
        title = models.CharField(verbose_name="标题", max_length=32)
    
  • 命令

    python manage.py makemigrations
    
    python manage.py migrate app01 --database=default
    
    python manage.py migrate app02 --database=bak
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hql4Q7xd-1691504274638)(assets/image-20220710105925961.png)]

  • 读写操作

    from django.shortcuts import render, HttpResponse
    
    from app01 import models as m1
    from app02 import models as m2
    
    
    def index(request):
        # app01中的操作 -> default
        v1 = m1.UserInfo.objects.all()
        print(v1)
    
        # app02中的操作 -> bak
        v2 = m2.Role.objects.using('bak').all()
        print(v2)
        return HttpResponse("返回")
    
  • router

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-i2zEQ9Rx-1691504274638)(assets/image-20220710110711518.png)]

1.4.3 分库(单app)

100张表,50表-A数据库;50表-B数据库。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IlBVSYSN-1691504274638)(assets/image-20220710111923985.png)]

from django.shortcuts import render, HttpResponse

from app01 import models as m1


def index(request):
    # app01中的操作 -> default
    v1 = m1.UserInfo.objects.all()
    print(v1)

    # app01中的操作 -> bak
    v2 = m1.Role.objects.using('bak').all()
    print(v2)

    return HttpResponse("返回")

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gAxGnF3B-1691504274639)(assets/image-20220710112344681.png)]

1.4.4 注意事项

  • 分库,表拆分到不用数据库。

    一定不要跨数据库做关联  -> django不支持
    
    怎么办?
    尽可能的将有关联的表放在一个库中。
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-j1qIs9kd-1691504274639)(assets/image-20220710112908647.png)]

  • 为什么表拆分到不同的库?

1.5 表关系

  • 单表

    class Role(models.Model):
        title = models.CharField(verbose_name="标题", max_length=32)
    
  • 一对多

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sJWVEnZZ-1691504274639)(assets/image-20220710115245095.png)]

  • 多对多
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8iI1KLWA-1691504274640)(assets/image-20220710115902277.png)]

    如果关系表中只有3列。

    class Boy(models.Model):
        """
        1   杰森斯坦森
        2   汤普森
        """
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
        b = models.ManyToManyField(to="Girl")
    
    class Girl(models.Model):
        """
        1   alex
        2   苑昊
        """
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
    
    class Boy(models.Model):
        """
        1   杰森斯坦森
        2   汤普森
        """
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
        
    class Girl(models.Model):
        """
        1   alex
        2   苑昊
        """
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
        b = models.ManyToManyField(to="Boy")
    
    class Boy(models.Model):
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
    
    
    class Girl(models.Model):
        name = models.CharField(verbose_name="标题", max_length=32, unique=True)
    
    
    class B2G(models.Model):
        bid = models.ForeignKey(to="Boy", on_delete=models.CASCADE)
        gid = models.ForeignKey(to="Girl", on_delete=models.CASCADE)
        address = models.CharField(verbose_name="地点", max_length=32)
    
  • 一对一

    表,100列     ->  50A表      50B表
    
    博客园为例:
    	- 注册,用户名、密码,无法创建博客
    	- 开通博客  地址/
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qIyKxHPs-1691504274640)(assets/image-20220710121216875.png)]

1.6 数据操作

  • 单表

    class Role(models.Model):
        title = models.CharField(verbose_name="标题", max_length=32)
    
    # obj1 = models.Role.objects.create(title="管理员", od=1)
    # obj2 = models.Role.objects.create(**{"title": "管理员", "od": 1})
    
    # 内存 -> save
    # obj = models.Role(title="客户", od=1)
    # obj.od = 100
    # obj.save()
    
    # obj = models.Role(**{"title": "管理员", "od": 1})
    # obj.od = 100
    # obj.save()
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9CzBzAyO-1691504274640)(assets/image-20220710143537101.png)]

    # models.Role.objects.all().delete()
    models.Role.objects.filter(title="管理员").delete()
    
    models.Role.objects.all().update(od=99)
    models.Role.objects.filter(id=7).update(od=99, title="管理员")
    models.Role.objects.filter(id=7).update(**{"od": 99, "title": "管理员"})
    
    # QuerySet = [obj, obj]
    v1 = models.Role.objects.all()
    for obj in v1:
        print(obj, obj.id, obj.title, obj.od)
    
    # QuerySet = []
    # v2 = models.Role.objects.filter(od=99, id=99)
    v2 = models.Role.objects.filter(**{"od": 99, "id": 99})
    for obj in v2:
        print(obj, obj.id, obj.title, obj.od)
        
    
    v3 = models.Role.objects.filter(id=99)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id__gt=2)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id__gte=2)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id__lt=2)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id__in=[11, 22, 33])
    print(v3.query)
    
    v3 = models.Role.objects.filter(title__contains="户")
    print(v3.query)
    
    v3 = models.Role.objects.filter(title__startswith="户")
    print(v3.query)
    
    v3 = models.Role.objects.filter(title__isnull=True)
    print(v3.query)
    
    v3 = models.Role.objects.filter(id=99)
    print(v3.query)
    # 不等于
    v3 = models.Role.objects.exclude(id=99).filter(od=88)
    print(v3.query)
    
    # queryset=[obj,obj]
    v3 = models.Role.objects.filter(id=99)
    
    # queryset=[{'id': 6, 'title': '客户'}, {'id': 7, 'title': '客户'}]
    v4 = models.Role.objects.filter(id__gt=0).values("id", 'title')
    
    # QuerySet = [(6, '客户'), (7, '客户')]
    v5 = models.Role.objects.filter(id__gt=0).values_list("id", 'title')
    print(v5[0])
    
    v6 = models.Role.objects.filter(id__gt=0).first()
    # print(v6)  # 对象
    
    v7 = models.Role.objects.filter(id__gt=10).exists()
    print(v7)  # True/False
    
    # asc
    v8 = models.Role.objects.filter(id__gt=0).order_by("id")
    
    # id desc  od asc
    v9 = models.Role.objects.filter(id__gt=0).order_by("-id", 'od')
    
  • 一对多

    class Depart(models.Model):
        """ 部门 """
        title = models.CharField(verbose_name="标题", max_length=32)
    
    
    class Admin(models.Model):
        name = models.CharField(verbose_name="姓名", max_length=32)
        pwd = models.CharField(verbose_name="密码", max_length=32)
    
        depart = models.ForeignKey(verbose_name="部门", to="Depart", on_delete=models.CASCADE)
    
    models.Admin.objects.create(name='武沛齐1', pwd='123123123', depart_id=2)
    # models.Admin.objects.create(**{..})
    
    obj = models.Depart.objects.filter(id=2).first()
    models.Admin.objects.create(name='武沛齐2', pwd='123123123', depart=obj)
    models.Admin.objects.create(name='武沛齐2', pwd='123123123', depart_id=obj.id)
    
    # filter()   # 当前表的字段 + depart__字段    -> 连表和条件
    
    # 找到部门id=3的所有的员工,删除
    # models.Admin.objects.filter(depart_id=3).delete()
    
    # 删除销售部的所有员工
    # obj = models.Depart.objects.filter(title="销售部").first()
    # models.Admin.objects.filter(depart_id=obj.id).delete()
    
    # models.Admin.objects.filter(depart__title="销售部", name='武沛齐').delete()
    
    # 1. select * from admin    					queryset=[obj,obj,]
    v1 = models.Admin.objects.filter(id__gt=0)
    for obj in v1:
        print(obj.name, obj.pwd, obj.id, obj.depart_id)
    
    # 2. select * from admin inner join depart      queryset=[obj,obj,]
    v2 = models.Admin.objects.filter(id__gt=0).select_related("depart")
    for obj in v2:
        print(obj.name, obj.pwd, obj.id, obj.depart_id, obj.depart.title)
    
    # 3. select id,name.. from admin inner join depart      queryset=[{},{}]
    v3 = models.Admin.objects.filter(id__gt=0).values("id", 'name', 'pwd', "depart__title")
    print(v3)
    
    # 4. select id,name.. from admin inner join depart      queryset=[(),()]
    v4 = models.Admin.objects.filter(id__gt=0).values_list("id", 'name', 'pwd', "depart__title")
    print(v4)
    
    # 查询
    # models.Admin.objects.filter(id=2).update(name='xxx', pwd='xxxx')
    # models.Admin.objects.filter(name="武沛齐").update(depart_id=2)
    
    # models.Admin.objects.filter(id=2).update(depart__title="技术部")  -> 只能更新自己表字段
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hFndAp7E-1691504274640)(assets/image-20220710164040495.png)]

  • 多对多

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R0kfJTaS-1691504274641)(assets/image-20220710170440957.png)]

    from django.db import models
    
    
    class Boy(models.Model):
        name = models.CharField(verbose_name="姓名", max_length=32, db_index=True)
    
    
    class Girl(models.Model):
        name = models.CharField(verbose_name="姓名", max_length=32, db_index=True)
    
    
    class B2G(models.Model):
        bid = models.ForeignKey(to="Boy", on_delete=models.CASCADE)
        gid = models.ForeignKey(to="Girl", on_delete=models.CASCADE)
        address = models.CharField(verbose_name="地点", max_length=32)
    
    def index(request):
        # models.Boy.objects.create(name="宝强")
        # models.Boy.objects.create(name="羽凡")
        # models.Boy.objects.create(name="乃亮")
        #
        # models.Girl.objects.bulk_create(
        #     objs=[models.Girl(name="小路"), models.Girl(name="百合"), models.Girl(name="马蓉")],
        #     batch_size=3
        # )
    
        # 创建关系
        # models.B2G.objects.create(bid_id=1, gid_id=3, address="北京")
        # models.B2G.objects.create(bid_id=1, gid_id=2, address="北京")
        # models.B2G.objects.create(bid_id=2, gid_id=2, address="北京")
        # models.B2G.objects.create(bid_id=2, gid_id=1, address="北京")
    
        # b_obj = models.Boy.objects.filter(name='宝强').first()
        # g_object = models.Girl.objects.filter(name="小路").first()
        # models.B2G.objects.create(bid=b_obj, gid=g_object, address="北京")
    
        # 1.宝强都与谁约会。
        # queyset=[obj,obj,obj]
        # q = models.B2G.objects.filter(bid__name='宝强').select_related("gid")
        # for item in q:
        #     print(item.id, item.address, item.bid.name, item.gid.name)
    
        # q = models.B2G.objects.filter(bid__name='宝强').values("id", 'bid__name', 'gid__name')
        # for item in q:
        #     print(item['id'], item['bid__name'], item['gid__name'])
    
        # 2.百合 都与谁约会。
        # q = models.B2G.objects.filter(gid__name='百合').values("id", 'bid__name', 'gid__name')
        # for item in q:
        #     print(item['id'], item['bid__name'], item['gid__name'])
    
        # 3.删除
        # models.B2G.objects.filter(id=1).delete()
        # models.Boy.objects.filter(id=1).delete()
    
        return HttpResponse("返回")
    
  • 一对一
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZqGIYz02-1691504274641)(assets/image-20220710173043956.png)]

2.cookie和session

2.1 cookie

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dZpX2Ofe-1691504274641)(assets/image-20220710174352897.png)]

127.0.0.1       v1.wupeiqi.com
127.0.0.1       v2.wupeiqi.com

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u9mqo9nb-1691504274641)(assets/image-20220710175925008.png)]

2.2 配置session

  • 文件版

    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        # 'django.contrib.auth.middleware.AuthenticationMiddleware',
        # 'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]
    
    
    # session
    SESSION_ENGINE = 'django.contrib.sessions.backends.file'
    SESSION_FILE_PATH = 'xxxx' 
    
    SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)
    
    SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    
  • 数据库

    INSTALLED_APPS = [
        # 'django.contrib.admin',
        # 'django.contrib.auth',
        # 'django.contrib.contenttypes',
        'django.contrib.sessions',
        # 'django.contrib.messages',
        'django.contrib.staticfiles',
        "app01.apps.App01Config",
    ]
    
    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        # 'django.contrib.auth.middleware.AuthenticationMiddleware',
        # 'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]
    
    
    # session
    SESSION_ENGINE = 'django.contrib.sessions.backends.db'
    
    SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)
    
    SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    
  • 缓存

    INSTALLED_APPS = [
        # 'django.contrib.admin',
        # 'django.contrib.auth',
        # 'django.contrib.contenttypes',
        # 'django.contrib.sessions',
        # 'django.contrib.messages',
        'django.contrib.staticfiles',
        "app01.apps.App01Config",
    ]
    
    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        # 'django.contrib.auth.middleware.AuthenticationMiddleware',
        # 'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]
    
    
    # session
    SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
    SESSION_CACHE_ALIAS = 'default' 
    
    SESSION_COOKIE_NAME = "sid"  # Session的cookie保存在浏览器上时的key,即:sessionid=随机字符串
    SESSION_COOKIE_PATH = "/"  # Session的cookie保存的路径
    SESSION_COOKIE_DOMAIN = None  # Session的cookie保存的域名
    SESSION_COOKIE_SECURE = False  # 是否Https传输cookie
    SESSION_COOKIE_HTTPONLY = True  # 是否Session的cookie只支持http传输
    SESSION_COOKIE_AGE = 1209600  # Session的cookie失效日期(2周)
    
    SESSION_EXPIRE_AT_BROWSER_CLOSE = False  # 是否关闭浏览器使得Session过期
    SESSION_SAVE_EVERY_REQUEST = True  # 是否每次请求都保存Session,默认修改之后才保存
    

3.缓存

  • 服务器 + redis安装启动

  • django

    • 安装连接redis包

      pip install django-redis
      
    • settings.py

      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": "密码",
              }
          }
      }
      
    • 手动操作redis

      from django_redis import get_redis_connection
      
      conn = get_redis_connection("default")
      conn.set("xx","123123")
      conn.get("xx")
      

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

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

相关文章

Metasploitable2靶机漏洞复现

一、信息收集 nmap扫描靶机信息 二、弱口令 1.系统弱口令 在Kali Linux中使用telnet远程连接靶机 输入账号密码msfadmin即可登录 2.MySQL弱口令 使用mysql -h 靶机IP地址即可连接 3.PostgreSQL弱密码登录 输入psql -h 192.168.110.134 -U postgres 密码为postgres 输入\…

线性代数(二) 矩阵及其运算

前言 行列式det(A) 其实表示的只是一个值 ∣ a b c d ∣ a d − b c \begin{vmatrix} a & b\\ c & d\end{vmatrix} ad -bc ​ac​bd​ ​ad−bc,其基本变化是基于这个值是不变。而矩阵表示的是一个数表。 定义 矩阵与线性变换的关系 即得 ( a 11 a 12…

数据结构——单链表的实现(c语言版)

前言 单链表作为顺序表的一种,了解并且熟悉它的结构对于我们学习更加复杂的数据结构是有一定意义的。虽然单链表有一定的缺陷,但是单链表也有它存在的价值, 它也是作为其他数据结构的一部分出现的,比如在图,哈希表中。…

java之junit Test

JUnit测试简介 1.什么是单元测试 单元测试是针对最小的功能单元编写测试代码Java程序最小的功能单元是方法单元测试就是针对单个Java方法的测试 2.测试驱动开发 3.单元测试的好处 确保单个方法运行正常如果修改了方法代码,只需确保其对应的单元测试通过测试代码…

【深度学习】【风格迁移】Visual Concept Translator,一般图像到图像的翻译与一次性图像引导,论文

General Image-to-Image Translation with One-Shot Image Guidance 论文:https://arxiv.org/abs/2307.14352 代码:https://github.com/crystalneuro/visual-concept-translator 文章目录 Abstract1. Introduction2. 相关工作2.1 图像到图像转换2.2. Di…

使用chatGPT生成提示词,在文心一言生成装修概念图

介绍 家是情感的港湾,而家居装修则是将情感融入空间的艺术。如何在有限的空间里展现个性与美感,成为了现代人关注的焦点。而今,随着人工智能的发展,我们发现了一个新的创意助手——ChatGPT,它不仅为我们带来了更多可能…

nodejs+vue+elementui招聘求职网站系统的设计与实现-173lo

(1)管理员的功能是最高的,可以对系统所在功能进行查看,修改和删除,包括企业和用户功能。管理员用例如下: 图3-1管理员用例图 (2)企业关键功能包含个人中心、岗位类型管理、招聘信息…

C语言每日一题:16:数对。

思路一&#xff1a;基本思路 1.x,y均不大于n&#xff0c;就是小于等于n。 2.x%y大于等于k。 3.一般的思路使用双for循环去遍历每一对数。 代码实现&#xff1a; #include <stdio.h> int main() {int n 0;int k 0;//输入scanf("%d%d", &n, &k);int x…

【深度学习注意力机制系列】—— ECANet注意力机制(附pytorch实现)

ECANet&#xff08;Efficient Channel Attention Network&#xff09;是一种用于图像处理任务的神经网络架构&#xff0c;它在保持高效性的同时&#xff0c;有效地捕捉图像中的通道间关系&#xff0c;从而提升了特征表示的能力。ECANet通过引入通道注意力机制&#xff0c;以及在…

【Plex】FRP内网穿透后 App无法使用问题

能搜索到这个文章的&#xff0c;应该都看过这位同学的分析【Plex】FRP内网穿透后 App无法使用问题_plex frp无效_Fu1co的博客-CSDN博客 这个是必要的过程&#xff0c;但是设置之后仍然app端无法访问&#xff0c;原因是因为网络端口的问题 这个里面的这个公开端口&#xff0c;可…

STM32 F103C8T6学习笔记1:开发环境与原理图的熟悉

作为一名大学生&#xff0c;学习单片机有一段时间了&#xff0c;也接触过嵌入式ARM的开发&#xff0c;但从未使用以及接触过STM32C8T6大开发使用&#xff0c;于是从今日开始&#xff0c;将学习使用它~ 本文介绍STM32C8T6最小系统开发环境搭建注意问题&#xff0c;STM32C8T6单片…

WPF上位机9——Lambda和Linq

Lambda Linq 操作集合 使用类sql形式查询 Linq To SQL

微服务学习笔记-基本概念

微服务是一种经过良好架构设计的分布式架构方案。根据业务功能对系统做拆分&#xff0c;每个业务功能模块作为独立项目开发&#xff0c;称为一个服务。 微服务的架构特征&#xff1a; 单一职责&#xff1a;微服务拆分粒度更小&#xff0c;每一个服务都对应唯一的业务能力&…

Vue实现详细界面里面有一个列表

目录 Vue实现详细界面里面有一个列表 理一下思路&#xff1a; 效果如下&#xff1a; 1、 主页面正常写 2、详细界面(重点) 3、详细界面里面的列表(重点) 要点&#xff1a; Vue实现详细界面里面有一个列表 理一下思路&#xff1a; 1、首先需要这条数据的主键id&#xff…

SpringSpringBoot常用注解

目录 一、核心注解二、Spring Bean 相关2.1 Autowired2.2 Component, Repository, Service, Controller2.3 RestController 与 Controller2.4 Configuration 与 Component2.5 Scope 三、处理常见的 HTTP 请求类型3.1 GET 请求3.2 POST 请求3.3 PUT 请求3.4 DELETE 请求3.5 PATC…

【Python】背景及环境搭建

文章目录 了解计算机一、Python背景知识一、Python环境搭建 努力经营当下 直至未来明朗 了解计算机 示例&#xff1a;使用电脑访问B站 1&#xff09; 本地的计算机会给B站服务器发送一个网络请求&#xff08;如&#xff1a;谁&#xff0c;想看哪个视频&#xff09; 2&#xf…

MySQL8安装教程 保姆级(Windows))

下载 官网: mysql官网点击Downloads->MySQL Community(GPL) Downloads->MySQL Community Server(或者点击MySQL installer for Windows) Windows下有两种安装方式 在线安装 一般带有 web字样 这个需要联网离线安装 一般没有web字样 安装 下载好之后,版本号可以不一样&…

《系统架构设计师教程》重点章节思维导图

内容来自《系统架构设计师教程》&#xff0c;筛选系统架构设计师考试中分值重点分布的章节&#xff0c;根据章节的内容整理出相关思维导图。 重点章节 第2章&#xff1a;计算机系统知识第5章&#xff1a;软件工程基础知识第7章&#xff1a;系统架构设计基础知识第8章&#xff1…

尚硅谷大数据项目《在线教育之采集系统》笔记003

视频地址&#xff1a;尚硅谷大数据项目《在线教育之采集系统》_哔哩哔哩_bilibili 目录 P036 P037 P038 P039 P041 P042 P043 P044 P045 P046 P036 先启动zookeeper&#xff0c;在启动kafka&#xff0c;启动hadoop中的hdfs node003启动flume&#xff0c;node001启动f…

云原生网关API标准背景及发展现状

Gateway API是一个开源的API标准&#xff0c;源自Kubernetes SIG-NETWORK兴趣组。从出身角度讲&#xff0c;可谓根正苗红&#xff0c;自从开源以来备受关注&#xff0c;被寄予厚望。Gateway API旨在通过声明式、可扩展性和面向角色的接口来发展Kubernetes服务网络&#xff0c;并…