zoukankan      html  css  js  c++  java
  • Python

    用 CharField 定义的字段在数据库中存放为 verchar 类型

    自定义 char 类型字段需要下面的代码:

    class FixedCharField(models.Field):
        """
        自定义的 char 类型的字段类
        """
        def __init__(self, max_length, *args, **kwargs):
            self.max_length = max_length
            super(FixedCharField, self).__init__(max_length=max_length, *args, **kwargs)
    
        def db_type(self, connection):
            """
            限定生成数据库表的字段类型为 char,长度为 max_length 指定的值
            """
            return 'char(%s)' % self.max_length
    

    models.py:

    from django.db import models
    
    
    class FixedCharField(models.Field):
        """
        自定义的 char 类型的字段类
        """
        def __init__(self, max_length, *args, **kwargs):
            self.max_length = max_length
            super(FixedCharField, self).__init__(max_length=max_length, *args, **kwargs)
    
        def db_type(self, connection):
            """
            限定生成数据库表的字段类型为 char,长度为 max_length 指定的值
            """
            return 'char(%s)' % self.max_length
    
    
    class Person(models.Model):
        id = models.AutoField(primary_key=True)   # 自增的 id 主键
        name = models.CharField(max_length=32)
        sex = FixedCharField(max_length=32, default="Man")  # 使用上面自定义的char类型的字段
        age = models.IntegerField()
        birthday = models.DateField(auto_now_add=True)
    

    执行命令更新到数据库

  • 相关阅读:
    Number Two
    蝴蝶结
    webug3.0靶场渗透基础Day_1
    SQL SERVER2014的安装
    SQLILABS学习笔记(一)
    关于暴力破解的一些学习笔记(pikachu)
    sql注入学习笔记
    CSRF与平行越权的区别
    任意文件下载(pikachu)
    XSS跨站脚本攻击学习笔记(pikachu)
  • 原文地址:https://www.cnblogs.com/sch01ar/p/11285028.html
Copyright © 2011-2022 走看看