基于django 的orm中非主键自增的实现方式

作者:金子的日常 时间:2023-06-04 13:53:54 

我们知道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

标签:django,orm,非主键,自增
0
投稿

猜你喜欢

  • PHP脚本监控Nginx 502错误并自动重启php-fpm

    2023-09-26 00:11:45
  • Python利用百度地图获取两地距离(附demo)

    2022-10-18 23:21:33
  • django 读取图片到页面实例

    2023-02-22 13:30:50
  • pyqt5蒙版遮罩mask,setmask的使用

    2022-04-05 21:00:58
  • HTML:scrollLeft,scrollWidth,clientWidth,offsetWidth完全详解

    2024-04-22 22:25:25
  • Python爬虫爬取微信朋友圈

    2021-11-12 17:38:14
  • Javascript Closures (2)

    2009-03-18 12:22:00
  • MySQL窗口函数的具体使用

    2024-01-20 07:55:27
  • ORACLE数据库事务隔离级别介绍

    2012-10-07 10:43:36
  • python 如何用terminal输入参数

    2023-02-19 08:06:15
  • PHP策略模式定义与用法示例

    2024-05-13 09:21:04
  • Python开发之pip安装及使用方法详解

    2022-11-27 06:22:48
  • python获得图片base64编码示例

    2023-10-29 07:02:37
  • Ubuntu下Python+Flask分分钟搭建自己的服务器教程

    2023-11-12 04:37:43
  • 用python写asp详细讲解

    2022-02-26 13:21:36
  • Python深度学习实战PyQt5布局管理项目示例详解

    2023-03-11 08:47:37
  • ansible作为python模块库使用的方法实例

    2022-07-15 08:01:02
  • 学习python需要有编程基础吗

    2022-05-01 15:23:47
  • Express结合Webpack的全栈自动刷新

    2024-05-09 10:34:13
  • 简单聊聊Python中的鸭子类型和猴子补丁

    2022-06-17 00:32:58
  • asp之家 网络编程 m.aspxhome.com