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)
    

    执行命令更新到数据库

  • 相关阅读:
    feign.RetryableException: Read timed out
    字段重复性校验
    时间的问题总结
    Maven使用mvn命令生成一个spring mvc的web项目
    Mac OS安装brew
    Docker部署Web应用到Tomcat
    Docker安装使用Oracle 11g
    Python 修改AD密码
    Let's Encrypt 证书 wget 报错
    dedecms获取指定栏目下的文章数量
  • 原文地址:https://www.cnblogs.com/sch01ar/p/11285028.html
Copyright © 2011-2022 走看看