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


Posted in Python onMay 18, 2020

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

但是不能重复、

以上这篇基于django 的orm中非主键自增的实现方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现2048小游戏
Mar 30 Python
python实现xlsx文件分析详解
Jan 02 Python
Python二进制串转换为通用字符串的方法
Jul 23 Python
启动Atom并运行python文件的步骤
Nov 09 Python
python实现简单的文字识别
Nov 27 Python
Python 数据可视化pyecharts的使用详解
Jun 26 Python
Python @property及getter setter原理详解
Mar 31 Python
Django在Model保存前记录日志实例
May 14 Python
python基于exchange函数发送邮件过程详解
Nov 06 Python
Python接口自动化系列之unittest结合ddt的使用教程详解
Feb 23 Python
Python list列表删除元素的4种方法
Nov 01 Python
python 实现图片特效处理
Apr 03 Python
Mysql数据库反向生成Django里面的models指令方式
May 18 #Python
Jupyter notebook快速入门教程(推荐)
May 18 #Python
解决django 向mysql中写入中文字符出错的问题
May 18 #Python
Anaconda3中的Jupyter notebook添加目录插件的实现
May 18 #Python
python实现人像动漫化的示例代码
May 17 #Python
django日志默认打印request请求信息的方法示例
May 17 #Python
使用pyecharts1.7进行简单的可视化大全
May 17 #Python
You might like
DOTA2 1月28日更新:监管系统降临刀塔世界
2021/01/28 DOTA
PHP新手上路(六)
2006/10/09 PHP
如何实现JS函数的重载
2006/09/22 Javascript
从sohu弄下来的flash中展示图片的代码
2007/04/27 Javascript
JavaScript写的一个DIV 弹出网页对话框
2009/08/14 Javascript
Js 刷新框架页的代码
2010/04/13 Javascript
javascript中的取反再取反~~没有意义
2014/04/06 Javascript
html5+javascript制作简易画板附图
2014/04/25 Javascript
c#程序员对TypeScript的认识过程
2015/06/19 Javascript
微信小程序开发之视频播放器 Video 弹幕 弹幕颜色自定义实例
2016/12/08 Javascript
从零学习node.js之简易的网络爬虫(四)
2017/02/22 Javascript
AngularJS解决ng-if中的ng-model值无效的问题
2017/06/21 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
2017/10/18 Javascript
详解一个基于react+webpack的多页面应用配置
2019/01/21 Javascript
详解使用mocha对webpack打包的项目进行"冒烟测试"的大致流程
2020/04/27 Javascript
node.js如何根据URL返回指定的图片详解
2020/10/21 Javascript
vue-cli —— 如何局部修改Element样式
2020/10/22 Javascript
python标准日志模块logging的使用方法
2013/11/01 Python
Python 实现12306登录功能实例代码
2018/02/09 Python
Python pyinotify日志监控系统处理日志的方法
2018/03/08 Python
python线程中同步锁详解
2018/04/27 Python
浅谈Python中range与Numpy中arange的比较
2020/03/11 Python
Python unittest基本使用方法代码实例
2020/06/29 Python
Appium+Python实现简单的自动化登录测试的实现
2021/01/26 Python
python如何实现递归转非递归
2021/02/25 Python
优秀的茶餐厅创业计划书
2014/01/03 职场文书
市场营销方案范文
2014/03/11 职场文书
精神文明单位申报材料
2014/05/02 职场文书
教师群众路线心得体会
2014/11/04 职场文书
搞笑老公保证书
2015/02/26 职场文书
驾驶员管理制度范本
2015/08/06 职场文书
2016年国庆节宣传标语
2015/11/25 职场文书
2016年习主席讲话学习心得体会
2016/01/20 职场文书
Python实现socket库网络通信套接字
2021/06/04 Python
JavaScript中document.activeELement焦点元素介绍
2021/11/27 Javascript
详解Flutter和Dart取消Future的三种方法
2022/04/07 Java/Android