MongoDB中的主键是怎样的,怎样自定义主键
Admin 2022-05-27 群英技术资讯 1036 次浏览
mongodb中有主键,但是如果不对主键进行设置的话是默认主键。
1、默认主键
ObjectId 类似唯一主键,可以很快的去生成和排序,包含 12 bytes,含义是:
前 4 个字节表示创建 unix 时间戳,格林尼治时间 UTC 时间,比北京时间晚了 8 个小时
接下来的 3 个字节是机器标识码
紧接的两个字节由进程 id 组成 PID
最后三个字节是随机数
MongoDB 中存储的文档必须有一个 _id 键。这个键的值可以是任何类型的,默认是个 ObjectId 对象
由于 ObjectId 中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 getTimestamp 函数来获取文档的创建时间:
通过注释【@Id】设置主键,如果不设置主键,mongoDB会自动生成主键。
@Document @Data public class InvoicesMsg { private String customerId; private String orderId; private String money; private String time; private String qmz; public InvoicesMsg(String customerId, String orderId, String money, String time, String qmz) { this.customerId = customerId; this.orderId = orderId; this.money = money; this.time = time; this.qmz = qmz; } }
默认生成的数据
{ "_id": ObjectId("5cb7d0b95de26915c1433160"), "customerId": "5c73830e54bbb01d1051ef7d", "orderId": "0000000120190418090814000001", "money": "550", "time": "1555549694", "qmz": "a1fbbb8fc0d0f2d93c218efc2cd2de517156e30f", "date": "2019-04-18 09:19:53.396", "_class": "com.example.btest.demo.bean.InvoicesMsg" }
2、自定义主键
@Document @Data public class InvoicesMsg { public String id; //主键 private String customerId; private String orderId; private String money; private String time; private String qmz; public InvoicesMsg(String customerId, String orderId, String money, String time, String qmz) { this.customerId = customerId; this.orderId = orderId; this.money = money; this.time = time; this.qmz = qmz; } }
新增一条数据,给id设置值 "1122357" 作为主键
{ "_id": "1122357", "customerId": "00", "orderId": "1122357", "money": "10", "time": "1878678818", "qmz": "67d53fdccdf29a0686f3e351fe09d61340ea2c85", "date": "2019-04-19 11:25:29.253", "_class": "com.example.btest.demo.pojo.InvoicesMsg" }
可以看到,主键值设为了 1122357 ,但是字段仍然是_id 。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
count查询记录条数的方法:在mongodb数据库中使用“db.tablename.find().count();”命令即可查询记录数。
mongodb多表联查的方法:1、首先用from关联主从表名;2、用as查询结果名;3、用Aggregation进行多条件查询;4、查询结果赋给results;5、用print()输出查询结果。
这篇文章主要介绍的是mongodb官方的golang驱动的使用,包括导入,链接,删除慢,查询等操作,感兴趣的朋友可以参考参考,下面就跟随小编一起来学习吧。
MongoDB 分片 分片 在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求。 当MongoDB存储海量的数据时,一台机器可能不足以存储数据,也可能不足以提供可接受的读写吞吐量。这时,我们就可以通过在多台机器上分割数据,使得数据库系统能存储和处理更多的数据。 为什么使用分片 复制所有的写入操作到主节点 延迟的敏感数据会在主节点查询 单个副本集限制在12个节点 当请求量巨大时会出现内存不..
Node.js 连接 MongoDB MongoDB是一种文档导向数据库管理系统,由C++撰写而成。 本章节我们将为大家介绍如何使用 Node.js 来连接 MongoDB,并对数据库进行操作。 如果你还没有 MongoDB 的基本知识,可以参考我们的教程:MongoDB 教程。 安装驱动 本教程使用了淘宝定制的 cnpm 命令进行安装: $ cnpm install mongodb 接下来我们来实现增删改查功能。 创建数据库 ..
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008