基于django 的orm中非主键自增的实现方式
作者:金子的日常 发布时间:2023-06-04 13:53:54
标签:django,orm,非主键,自增
我们知道django的orm想实现自增,可以直接使用AutoField字段既可以实现,但是这种情况必须要求此字段是主键,但是我们知道主键只能是一个。
如果我已经有了一个主键,但是又需要另外一个字段为唯一自增字段,这该如何实现呢?
本人的解决办法如下,供大家参考,也欢迎大家提供更多的实现方式,互相学习。
class ProductSpu(models.Model):
"""
商品表
"""
_database = 'payment'
id = models.UUIDField(primary_key=True, default=uuid.uuid4, db_column='c_id')
product_no = models.IntegerField('商品号', blank=True, auto_created=True, db_column='c_product_no')
name = models.CharField(verbose_name='商品名称', max_length=100, db_column='c_name')
如上,product_no字段是我要实现的自增字段,
(1)首先设置此字段为IntegerField类型,并设置属性值auto_created=True;
(2)生成数据库的sql语句设置如下:
CREATE TABLE `ehr-payment`.`t_product_spu` (
`c_id` char(32) NOT NULL,
`c_product_no` int(11) NOT NULL AUTO_INCREMENT COMMENT '商品编码',
`c_name` varchar(100) NOT NULL COMMENT '商品名称',
PRIMARY KEY (`c_id`),
UNIQUE KEY `c_product_no` (`c_product_no`)
) ENGINE=InnoDB AUTO_INCREMENT=100001 DEFAULT CHARSET=utf8 COMMENT='商品表';
经过如上两点配合设置,新增一条数据是会自动填充自增字段product_no,其中通过sql配置 AUTO_INCREMENT=100001,实现自增字段开始的值。如,此例是从100001开始自增。
补充知识:django关于自增id的问题
在django中,如果创建模型。不指定id。django会自动自定一个id
class Student(models.Model):
name = models.CharField(max_length=16)
sex = models.CharField(max_length=4)
像这种情况。django会自动添加一个自增id
在数据库的表结构为
id name sex
相当于
class Student(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=16)
sex = models.CharField(max_length=4)
然后这id是自增的。
如果需要自定义id,然后这个id值是可用自己定义。那么就需要这样做即可
class Student(models.Model):
u_id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=16)
sex = models.CharField(max_length=4)
把AutoField 修改为IntegerField 即可
这样创建的数据。数据库的id值。就不是自增的。可用在插入sql的时候指定 u_id 的值为3,6,8等。
但是不能重复、
来源:https://blog.csdn.net/weixin_42813985/article/details/86493163
0
投稿
猜你喜欢
- 基于tkinter模块的GUIGUI是图形用户界面的缩写,图形化的用户界面对使用过计算机的人来说应该都不陌生,在此也无需进行赘述。Pytho
- 本文实例为大家分享了python实现俄罗斯方块的具体代码,供大家参考,具体内容如下# teris.py# A module for game
- 运行环境IDE丨pycharm版本丨Python3.6系统丨Windows实现目的与思路目的实现对腾讯视频目标url的解析与下载,由于第三方
- 如下所示:def resize(src, dsize, dst=None, fx=None, fy=None, interpolation=
- 我想大多写web的朋友应该和我一样,正则是不可少的,可是每次到用时去百度一下,也麻烦,存在电脑里也得找半天~换了电脑还是得靠google了~
- 1. txt文件(1) 单位矩阵即主对角线上的元素均为1,其余元素均为0的正方形矩阵。在NumPy中可以用eye函数创建一个这样的二维数组,
- 1.算法:(设查找的数组期间为array[low, high])(1)确定该期间的中间位置K(2)将查找的值T与array[k]比较。若相等
- 目录创建文件夹布局编写命令代码实际应用场景案例1:检查数据库连接是否已就绪案例2:周期性发送邮件每次在启动Django服务之前,我们都会在终
- 逻辑门是任何数字电路的基本构建块。它需要一两个输入并根据这些输入产生输出。输出可能为高 (1) 或低 (0)。逻辑门使用二极管或晶体管实现。
- optimizer.param_groups: 是长度为2的list,其中的元素是2个字典;optimizer.param_groups[0
- 鼠标经过超链时的提示图层源码运行代码框<script>var oPopup = window.createPopup();fun
- 本文实例讲述了Python动态生成多维数组的方法。分享给大家供大家参考,具体如下:多维数组其实就是多个一维数组的嵌套,Python中有原生的
- 它在Lynx里也会运行得很好:<%@ Language=VBScript %><HTML><
- php cookie中不能使用点号(句号),实际上不是很严格,应该说可以使用点号的cookie名,但会被转换,你命名一个cookie:$_C
- 今天,使用各种所见即所得工具制作主页已经是一件非常容易的事情了。但是了解HTML源代码和语法,无疑对我们制作主页有更大的帮助,也可以使用户能
- 1.反变换法设需产生分布函数为F(x)的连续随机数X。若已有[0,1]区间均匀分布随机数R,则产生X的反变换公式为:F(x)=r, 即x=F
- 前言在c++中参数传递有两种形式:值传递和引用传递。这两种方式的区别我不在此说,自行补上,如果你不知道的话。我先上python代码,看完我们
- 确定数据库内有多少记录,或者确定有多少记录达到了某些标准,这些用ASP完成并非难事。如果你采用了正确的游标类型,你可以用RecordCoun
- 1、requests 的常见用法requests 除了 url 之外,还有 params, data 和 files 三个参数,用于和服务器
- 简单的LSTM问题,能够预测一句话的下一个字词是什么固定长度的句子,一个句子有3个词。使用one-hot编码各种引用import keras