首页>>后端>>Python->django如何不自动加id字段?

django如何不自动加id字段?

时间:2023-12-20 本站 点击:0

导读:本篇文章首席CTO笔记来给大家介绍有关django如何不自动加id字段的相关内容,希望对大家有所帮助,一起来看看吧。

Django里面怎么实现数据库视图啊 就是虚拟表

正经回答:先在数据库中建立好视图,然后django中建立对应的model。表所对应的类下面再建立一个Meta类,大致如下

class ViewModel(models.Model):

    """这个model类对应你所建立好的视图"""

    class Meta(object):

        """同理,该方法可用于使用mysql中任何已有的表,不仅是视图"""

        db_table = 'your_view' #显式指定表名,也就是你建立的视图的名字

        managed = false #默认是ture,设成false django将不会执行建表和删表操作

    # 建立字段间的映射

    #  需要注意的是,必须设一个字段为主键

    #  不然django会自动创建一个id字段为主键,引发错误

百度知道越来越辣鸡了,全是答非所问的。

Django 主键自增

from django.db import models

# Create your models here.

class Student(models.Model):

    student_id = models.BigAutoField(primary_key=True)

这是model定义。

默认情况下,自增id都是从1开始计数的。如果你想从10001开始,就需要手动创建一个对象,为其设置student_id为10001,以后创建对象的studeng_id就从10002开始自动增加。

first_student =models.Student(student_id=10001)

first_student.save()

更多相关内容参考刘江的Django教程

Django的orm中怎么让外键字段不加_id

外键在数据库中的默认字段名是它在模型中的属性名+_id。可以在创建外键时使用db_column参数显式地指定一个字段名,来覆盖这么默认字段名。

author = models.ForeignKey('Author', on_delete=models.CASCADE, db_column='foobar')

那么数据库中这个外键字段名就是foobar,而不是author_id。

django怎样获得框架自动定义的自增id字段

django自定义字段类型,实现非主键字段的自增

# -*- encoding: utf-8 -*-from django.db.models.fields import Field, IntegerFieldfrom django.core import checks, exceptionsfrom django.utils.translation import ugettext_lazy as _class AutoIncreField(Field):

description = _("Integer")

empty_strings_allowed = False

default_error_messages = { 'invalid': _("'%(value)s' value must be an integer."),

} def __init__(self, *args, **kwargs):

kwargs['blank'] = True

super(AutoIncreField, self).__init__(*args, **kwargs) def check(self, **kwargs):

errors = super(AutoIncreField, self).check(**kwargs) # 每张表只能设置一个字段为自增长字段,这个字段可以是主键,也可以不是主键,如果不是主键,则必须设置为一种“键(key)”

# (primary key)也是键(key)的一种,key还包括外键(foreign key)、唯一键(unique key)

errors.extend(self._check_key()) return errors def _check_key(self):

if not self.unique: return [

checks.Error( 'AutoIncreFields must set key(unique=True).',

obj=self,

id='fields.E100',

),

] else: return [] def deconstruct(self):

name, path, args, kwargs = super(AutoIncreField, self).deconstruct() del kwargs['blank']

kwargs['unique'] = True

return name, path, args, kwargs def get_internal_type(self):

return "AutoIncreField"

def to_python(self, value):

if value is None: return value try: return int(value) except (TypeError, ValueError): raise exceptions.ValidationError(

self.error_messages['invalid'],

code='invalid',

params={'value': value},

) def db_type(self, connection):

return 'bigint AUTO_INCREMENT'

def rel_db_type(self, connection):

return IntegerField().db_type(connection=connection) def validate(self, value, model_instance):

pass

def get_db_prep_value(self, value, connection, prepared=False):

if not prepared:

value = self.get_prep_value(value)

value = connection.ops.validate_autopk_value(value) return value def get_prep_value(self, value):

value = super(AutoIncreField, self).get_prep_value(value) if value is None: return None

return int(value) def contribute_to_class(self, cls, name, **kwargs):

assert not cls._meta.auto_field, "A model can't have more than one AutoIncreField."

super(AutoIncreField, self).contribute_to_class(cls, name, **kwargs)

cls._meta.auto_field = self def formfield(self, **kwargs):

return None

结语:以上就是首席CTO笔记为大家介绍的关于django如何不自动加id字段的全部内容了,希望对大家有所帮助,如果你还想了解更多这方面的信息,记得收藏关注本站。


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