- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个问题,但在 Google 中尚未找到答案。它是关于 Mongoose 并保存具有唯一字段的对象。
例如,我有一个模型,我们将其称为“产品”。它应该有一个唯一的数字ID,假设字段的名称是productId。现在我只是生成随机 16 位数字:
var id = (Math.random()+' ').substring(2,10)+(Math.random()+' ').substring(2,10);
然后创建产品:
var product = { productId: id }
Product.create(product, (err, product) => { rest goes here });
所以实际的问题是:我如何检查具有此 id 的产品是否已经存在,如果确实存在,则根据需要多次重新生成 id,直到没有具有此产品 ID 的产品,然后才创建它。
在架构中,我将 ProductId 定义为唯一字段。我想我必须对错误处理做一些事情,但我只是找不到具体的内容。
最佳答案
默认情况下,MongoDb 会为您创建一个唯一的对象 id,即使您懒得尝试创建 id。由于您还为产品创建了随机 ID,因此我的建议是您无需担心创建唯一 ID。
但是如果你真的坚持创建一个唯一的id,如果你添加唯一的属性,使用mongoose,此时如果有人试图添加一个不唯一的id,它会自动抛出一个错误。所以你不需要担心验证 Mongoose 默认处理它。
至于你查找用户的问题是否已经存在用户
如果再次尝试重新创建唯一 ID,则存在迭代时间未知的问题,它将在最坏的情况下运行。因此,考虑到最坏的情况会发生什么,假设它迭代超过 100 次。(从数学上来说 - 从概率角度来看,这 100 次迭代值可能不正确,但作为一个例子)。
所以如果你想捕获这个机会并继续前进,你可以这样做
function genId(){
return (Math.random()+' ').substring(2,10)+(Math.random()+' ').substring(2,10);
}
recreateOrInsert(genId());
function recreateOrInsert(id){
Product.find({productId:id},(err,data)=>{
if(err)throw err;
if(data.length==0){ //remember here data comes as an array
var product = { productId: id };
Product.create(product, (err, product) => { rest goes here });
}else{
recreateOrInsert(genId());
}
});
}
在这里,您将创建一个迭代计数未知的循环..所以您确实需要注意它..但至于您的问题,这就是方式
关于node.js - Mongoose 独特的现场处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54171004/
对于 Prometheus 指标集合,如标题,我真的找不到只能通过 type Summary 完成的用例。 ,似乎它们都可以通过 type Histogram 以某种方式完成还。 让我们以请求并发度量
这个问题在这里已经有了答案: Ignore case while using duplicated (1 个回答) 关闭 9 个月前。 使用不区分大小写的 unique(tolower(x)) 删除
应用程序监控服务的一个有用功能是每次发生新的、独特的错误/问题/异常时发送警报(例如电子邮件)(即不是每次发生)。要么只是第一次,要么最多每次 X 次(一天或一周等)。例如,这可以通过 Visual
应用程序监控服务的一个有用功能是每次发生新的、独特的错误/问题/异常时发送警报(例如电子邮件)(即不是每次发生)。要么只是第一次,要么最多每次 X 次(一天或一周等)。例如,这可以通过 Visual
我想要相当于 DB2 中 MySql 的 GROUP_CONCAT 功能。 我尝试过 DB2 的 XML Aggrigate 函数来合并 murows。 SELECT a.ID, sub
我正在运行 python 数据库迁移脚本 (Flask-Migrate) 并添加了 alembic.ddl.imp import DefaultImpl 来解决第一组错误,但现在我收到以下错误。我正在
我有一个逗号分隔的文件“myfile.csv”,其中第 5 列是日期/时间戳。 (mm/dd/yyyy hh:mm)。 我需要列出所有包含重复日期的行(有很多) 我正在通过 cygwin 为 WinX
我使用的是 MySQL 5.7。 我有一个表格如下: -------------------------------------------------- | id | currentcy_id |
所以我有一个像这样的 ng-repeat: Join Ride /md-switch> 但是,每个 md-switch 都有相同的模型,因此当我在 Control
据我了解, Mongoose 预保存 Hook 在将文档插入集合之前但在验证发生之后触发。因此,如果一次验证失败,则不会调用预保存 Hook 。 就我而言,无论如何都会调用它们: 下面的简单代码的作用
如果我对我的目标文件执行此 grep,我会得到例如 275 作为结果。 但是我想学习 awk,所以在 awk 中尝试了这个: awk 'BEGIN { count=0 } /my pattern/
我是一名优秀的程序员,十分优秀!