首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MongoDB主键:使用ObjectId () 设置_id字段

在MongoDB中,_id字段是集合的主键,以便可以在集合中唯一地标识每个文档。_id字段包含唯一的Object ID 值。...默认情况下,在集合中插入文档时,如果您没有在字段名称中添加带有_id的字段名称,则MongoDB将自动添加一个Object id字段,下图所示: ?...如果要确保在创建集合时MongoDB不会创建_id字段,并且要指定自己的ID作为集合的_id,则需要在创建集合时明确定义它。 在显式创建id字段时,需要使用名称中的_id创建它。...我们假设正在创建集合中的第一个文档,因此在创建集合时在上述语句中,我们显式定义了字段_id并为其定义了一个值。 如果命令执行成功,现在使用find命令显示集合中的文档,则将显示以下输出结果: ?...结果显示表明,我们在创建集合时定义的_id字段现在作为集合的主键。 译者:徐杨 MongoDB中文社区翻译志愿者,资深程序员。

5.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    别再使用 TIMESTAMP 作为日期字段~

    例如用户表 User有register_date、last_modify_date两个字段的定义: CREATE TABLE User (     id BIGINT NOT NULL AUTO_INCREMENT...CURRENT_TIMESTAMP(6) ON UPDATE CURRENT_TIMESTAMP(6),     CHECK (sex = 'M' OR sex = 'F'),     PRIMARY KEY(id...如果想使用 TIMESTAMP 的时区功能,你可以通过下面的语句将之前的用户表 User 的注册时间字段类型从 DATETIME(6) 修改为 TIMESTAMP(6): ALTER TABLE User...所以,日期字段推荐使用 DATETIME,没有时区转化。即便使用 TIMESTAMP,也需要在数据库中显式地配置时区,而不是用系统时区。...例如,在前面的表 User 中的字段 last_modify_date,就是用于表示最后一次的修改时间: CREATE TABLE User (     id BIGINT NOT NULL AUTO_INCREMENT

    1.1K10

    使用 MongoRepository 按ID以外字段进行删除操作

    根据除 _id 以外的字段进行删除,可以使用自定义的查询方法来实现。可以在自定义的查询方法中使用 MongoDB 的查询语法来指定删除条件,从而根据其他字段进行删除。...0 }") void deleteByFieldName(String fieldName); } 定义了一个自定义的查询方法 deleteByFieldName,使用 @Query 注解指定了删除条件...在查询语句中,使用字段名 fieldName,根据实际情况替换为要删除的字段名。通过这个自定义的查询方法,根据指定的字段值进行删除操作。...总结 MongoRepository 默认的删除方法是根据 _id 字段进行删除的,根据除 _id 以外的字段进行删除,可以使用自定义的查询方法来实现。

    35220

    使用关键字作为字段名称

    但由于Oracle中双引号内的字符串是区分大小写的,而不管创建表还是查询时,Oracle都会把字段名转成全部大写,所以,除非创建表时双引号内的字段名就是全大写的,否则以后查询时SQL语句都必须加双引号,...若不加则Oracle内部会把字段名转成全大写从而提示“无效的标识符”。...同理,查询普通字段也可以通过加双引号查询得出,但双引号内的字段名必须是全大写,例如SELECT "ANY_FIELD_NAME" FROM TableName 在SQL Server 中可以用方括号[]...字段名任何情况下都不区分大小写。 在MySQL 中用`(backticks)把表和列名名字围起来。字段名也不区分大小写。...在Hibernate 中必须在定义映射关系时用backticks(`)包围字段名,具体参考这里 或这里 。

    1.6K10

    MongoDB-_id字段的含义介绍

    MongoDB中的主键无需明确指定,每一条记录被添加到集合之后, MongoDB都会自动添加主键,MongoDB中文档主键的名称叫做 _id,是一个ObjectId类型的数据,格式如下: study...> db.user.find() [ { _id: ObjectId("62c44b4d5604b99daa91103e"), name: '小博' } ] 数一下_id这个字段的长度,我们发现一共有24...位,我们将_id字段的内容拆分成4部分去分别看其对应的含义: 62c44b4d 5604b9 9daa 91103e 1-8位字符:插入数据的时候对应的时间戳 9-14位字符:代表主机的唯一标识符...= 62c6fdb6e3a9741ea11d9883为例,1-8位为62c6fdb6,将16进制转换为1657208246,这个就是对应的数据插入的时间,转换为时间格式后为: _id字段虽然为系统自动生成的一个唯一标识...,但是,用户也可以自定义这个id的值: db.getCollection("user").insert({ "_id":"1", "name": "大刀王五", "age": 29

    1.1K20

    第11课 使用子查询使用计算字段作为子查询

    检索包含物品‘RGAN01’的所有订单号 从这个订单号里到orders表里检索出custid 再根据custid从customers的表里检索顾客的信息 上面三个步骤每个步骤都可以单独作为一个查询来执行...不使用子查询“ select order_num from orderitems where prod_id = 'RGAN01'; select cust_id from orders where...order_num in (20007,20008) 使用子查询: select cust_id from orders where order_num in (select order_num from...orderitems where prod_id = 'RGAN01'); 使用计算字段作为子查询 假设有这么一个问题,显示customers表中的每个顾客订单的总数: 第一步,自然是检索出所有顾客的列表...= customers.cust_id ) as orders from customers order by cust_name;

    1.4K20

    如何使用 Django 更新模型字段(包括外键字段)

    常见的方式是使用模型实例的 save() 方法来保存修改。对于外键字段的更新,我们可以使用直接设置外键字段的方式,而不需要每次都查询外键表中的对象。...这种方式不需要每次都查询外键表(例如 Student 表)中的对象,而是直接使用外键的 ID 进行更新操作。...IDnew_student_id = 12 # 替换成新的学生IDtry: # 获取成绩记录 score = Score.objects.get(id=score_id) # 使用...attrs 方式更新学生字段 score.student_id = new_student_id # 保存修改 score.save() print("成绩记录中的学生字段更新成功...高级用法:使用 update() 方法批量更新字段除了直接设置外键字段外,还可以使用 Django 的 update() 方法来批量更新查询集中的对象。

    28110

    “禁止用 select * 作为查询字段列表”落地指南

    一、背景 《阿里巴巴 Java 开发手册》 MySQL 数据库部分,ORM 映射部分,谈到: 【强制】 在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。...【1】继续使用 UserDO 作为方法返回值: >: 省事,减少对象定义 >: 无法根据函数名或返回值明确知道哪些属性被赋值哪些属性没有被赋值。...3.3 结论 【推荐】如果业务上明确只需要部分字段时,可以使用通用接口获取所有字段,然后上层只取用需要的字段即可。...使用通用查询接口(通过id 获取整个DO 对象),可以更大程度上实现代码复用。...正例: String getEmailById(Long id) UserSimpleDO getSimpleById(Long id) [1] 如果使用容易歧义的类通用化的函数名称,返回值是通用的

    1K20

    “禁止用 select * 作为查询字段列表”落地指南

    一、背景 《阿里巴巴 Java 开发手册》 MySQL 数据库部分,ORM 映射部分,谈到: 【强制】 在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。...【1】继续使用 UserDO 作为方法返回值: >: 省事,减少对象定义 >: 无法根据函数名或返回值明确知道哪些属性被赋值哪些属性没有被赋值。...3.3 结论 【推荐】如果业务上明确只需要部分字段时,可以使用通用接口获取所有字段,然后上层只取用需要的字段即可。...使用通用查询接口(通过id 获取整个DO 对象),可以更大程度上实现代码复用。...正例: String getEmailById(Long id) UserSimpleDO getSimpleById(Long id) [1] 如果使用容易歧义的类通用化的函数名称,返回值是通用的

    95610

    字段变化引发的Power Pivot导入数据问题

    在使用Excel Power Pivot制造超级透视表的时候,很多人喜欢将外部数据直接导入Power Pivot,而不是使用Power Query预处理一番。...例如,我们有如下店铺资料工作簿,另外有个进行数据分析的工作簿,需要将店铺资料导入。...打开数据分析工作簿Power Pivot后台,选择“从其他源”-“Excel文件”: 选择准备好的店铺资料表,并勾选“将第一行作为列标题”。...数据顺利的导入到了Power Pivot中: 看上去一切顺利,直到有一天,你的数据源因为各种原因需要变更字段。...非常遗憾,由于外部数据是直接通过Power Pivot导入的,新增的字段并不会自动显示,需要我们做一些额外的设置。

    1.4K30
    领券