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)
    

    执行命令更新到数据库

  • 相关阅读:
    Day1_Python基础
    选择排序(java版)
    冒泡排序(java版)
    手写数据库连接池(动态代理)
    JDBC增删查改(使用配置文件)
    JDBC demo
    JSP入门&会话技术
    response实现验证码图片
    android 定制自己的日志工具
    服务的最佳实践——后台执行的定时任务
  • 原文地址:https://www.cnblogs.com/sch01ar/p/11285028.html
Copyright © 2011-2022 走看看