MongoDB的常用命令(数据库操作、集合操作、文档操作)

文章目录

  • 1. 数据库操作
    • 1.1 数据库的命名规范
    • 1.2 选择数据库和创建数据库
    • 1.3 删除数据库
    • 1.4 查看所有数据库
    • 1.5 查看当前正在使用的数据库
  • 2. 集合操作
    • 2.1 集合的命名规范
    • 2.2 集合的显式创建
    • 2.3 集合的隐式创建
    • 2.4 删除集合
    • 2.5 查看当前数据库中的所有集合
  • 3. 文档操作
    • 3.1 文档的键值对
    • 3.2 文档的键的命名规范
    • 3.3 插入文档
      • 3.3.1 单个文档插入
      • 3.3.2 批量插入
      • 3.3.3 批量插入中的异常处理
    • 3.4 查询文档
      • 3.4.1 查询所有文档
      • 3.4.2 条件查询
      • 3.4.3 投影查询
    • 3.5 文档的更多查询
      • 3.5.1 正则的复杂条件查询(模糊查询)
      • 3.5.2 比较查询
      • 3.5.3 包含查询
      • 3.5.4 条件连接查询
    • 3.6 分页列表查询
    • 3.7 排序查询
    • 3.8 查询的执行顺序
    • 3.9 文档更新
      • 3.9.1 更新集合中的第一个匹配的文档
        • 3.9.1.1 覆盖修改(了解即可)
        • 3.9.1.2 局部修改
      • 3.9.2 批量更新
      • 3.9.3 列值增长的修改
    • 3.10 删除文档
      • 3.10.1 删除集合中匹配到的第一个文档
      • 3.10.2 删除所有匹配到的文档
    • 3.11 统计查询
      • 3.11.1 统计所有记录数
      • 3.11.2 按条件统计记录数

阅读本文前可以先阅读以下文章:

  • MongoDB快速入门(MongoDB简介、MongoDB的应用场景、MongoDB中的基本概念、MongoDB的数据类型、MongoDB的安装与部署、MongoDB的常用命令)
  • Windows环境安装MongoDB
  • Linux环境安装MongoDB

1. 数据库操作

1.1 数据库的命名规范

数据库名可以是满足以下条件的任意 UTF-8 字符串:

  1. 不能是空字符串
  2. 不得含有 空格.$/\\0 等符号
  3. 全部小写
  4. 最多 64 字节

有一些数据库名是保留的,可以直接访问这些有特殊作用的数据库

  • admin: 从权限的角度来看,这是root数据库。如果将一个用户添加到这个数据库,这个用户会自动继承所有数据库的权限。一些特定的服务器端命令也只能从这个数据库运行,比如列出所有的数据库或者关闭服务器
  • local: 这个数据永远不会被复制,可以用来存储限于本地单台服务器的任意集合
  • config: 当Mongo用于分片设置时,config数据库在内部使用,用于保存分片的相关信息

1.2 选择数据库和创建数据库

选择数据库和创建数据库的语法如下(如果数据库不存在会自动创建

use 数据库名称;

1.3 删除数据库

主要用来删除已经持久化的数据库

db.dropDatabase();

1.4 查看所有数据库

查看所有的数据库(有权限查看的数据库)

show databases;

1.5 查看当前正在使用的数据库

MongoDB 中默认的数据库为 test,如果没有选择数据库,集合将存放在 test 数据库中

db;

2. 集合操作

集合类似与关系型数据库中的表

2.1 集合的命名规范

  1. 集合名不能是空字符串
  2. 集合名不能含有 \0 字符(空字符),这个字符表示集合名的结尾
  3. 集合名不能以 system.开头,这是为系统集合保留的前缀
  4. 用户创建的集合名字不能含有保留字符。有些驱动程序的确支持在集合名里面包含,这是因为某些系统生成的集合中包含该字符。除非你要访问这种系统创建的集合,否则千万不要在名字里出现$

2.2 集合的显式创建

db.createCollection(集合名称);

2.3 集合的隐式创建

当向一个集合中插入一个文档的时候,如果集合不存在,则会自动创建集合

2.4 删除集合

如果成功删除集合,则 drop() 方法返回 true,否则返回 false

删除当前集合

db.collection.drop();

删除指定的集合

db.集合名称.drop();

2.5 查看当前数据库中的所有集合

show collections;

3. 文档操作

3.1 文档的键值对

  1. 文档中的键值对是有序的
  2. 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)
  3. MongoDB 区分类型和大小写
  4. MongoDB 的文档不能有重复的键
  5. 文档的键是字符串,除了少数例外情况,键可以使用任意 UTF-8 字符

3.2 文档的键的命名规范

  • 键不能含有 \0 (空字符),这个字符用来表示键的结尾
  • .$ 有特别的意义,只有在特定环境下才能使用
  • 以下划线 _ 开头的键是保留的(不是严格要求)

3.3 插入文档

3.3.1 单个文档插入

使用 insertOne() 方法向集合中插入文档,语法如下:

db.collection.insertOne(<document or array of documents>,{writeConcern: <document>,ordered: <boolean>}
);
参数名描述
collection插入文档的集合名称
<document or array of documents>要插入的一个文档或者文档数组
writeConcern可选参数,用于指定写入的安全级别
ordered可选参数,默认为 true。如果设置为 true,MongoDB会按照数组中的顺序插入文档,并在遇到错误时停止。如果设置为 false,MongoDB会尝试插入所有文档,即使某些文档插入失败

下面是一个简单的例子,往 comment 集合中插入一条测试数据

db.comment.insertOne({article_id: 100000,content: "今天天气真好,阳光明媚",user_id: "1001",nickname: "Rose",create_time: new Date(),like_number: NumberInt(10),state: null
});
  1. comment 集合如果不存在,则会隐式创建
  2. MongoDB 中的数字,默认情况下是 double 类型,如果要存整型,必须使用函数 NumberInt(整型数字),否则取出来就有问题了
  3. 插入当前日期使用 new Date()
  4. 插入的数据没有指定 _id ,会自动生成主键值
  5. 如果某字段没值,可以赋值为 null,或不写该字段

成功插入文档之后 MongoDB 返回的结果

{acknowledged: true,insertedId: ObjectId('6728a523d9496fae23c4c2a9')
}

3.3.2 批量插入

使用 insertMany() 方法向集合中插入文档,语法如下:

db.collection.insertMany([ <document 1>, <document 2>, ... ],{writeConcern: <document>,ordered: <boolean>}
)

参数说明:

参数名类型说明
[ <document 1>, <document 2>, ... ]数组包含多个文档的数组,每个文档都是一个要插入的JSON对象
writeConcern文档可选参数,表示写操作的确认级别
ordered布尔值可选参数,默认为true。如果设置为true,则按顺序插入文档,如果插入失败则回滚所有更改。如果设置为false,则不按顺序插入,忽略插入失败的文档

下面是一个简单的例子,往 comment 集合中批量插入五条测试数据

  • 插入时指定了 _id ,则主键就是该值
  • 如果某条数据插入失败,将会终止插入,但已经插入成功的数据不会回滚掉
db.comment.insertMany([{_id: "1",article_id: "100001",content: "我们不应该把清晨浪费在手机上,健康很重要,一杯温水幸福你我他。",user_id: "1002",nickname: "相忘于江湖",create_time: new Date("2019-08-05T22:08:15.522Z"),like_number: NumberInt(1000),state: "1"},{_id: "2",article_id: "100001",content: "我夏天空腹喝凉开水,冬天喝温开水",user_id: "1005",nickname: "伊人憔悴",create_time: new Date("2019-08-05T23:58:51.485Z"),like_number: NumberInt(888),state: "1"},{_id: "3",article_id: "100001",content: "我一直喝凉开水,冬天夏天都喝。",user_id: "1004",nickname: "杰克船长",create_time: new Date("2019-08-06T01:05:06.321Z"),like_number: NumberInt(666),state: "1"},{_id: "4",article_id: "100001",content: "专家说不能空腹吃饭,影响健康。",user_id: "1003",nickname: "凯撒",create_time: new Date("2019-08-06T08:18:35.288Z"),like_number: NumberInt(2000),state: "1"},{_id: "5",article_id: "100001",content: "研究表明,刚烧开的水千万不能喝,因为烫嘴。",user_id: "1003",nickname: "凯撒",create_time: new Date("2019-08-06T11:01:02.521Z"),like_number: NumberInt(3000),state: "1"}
]);

成功插入文档之后 MongoDB 返回的结果

{acknowledged: true,insertedIds: {'0': '1','1': '2','2': '3','3': '4','4': '5'}
}

3.3.3 批量插入中的异常处理

因为批量插入由于数据较多容易出现失败,可以使用 try catch 进行异常捕捉处理

try {db.comment.insertMany([{_id: "1",article_id: "100001",content: "我们不应该把清晨浪费在手机上,健康很重要,一杯温水幸福你我他。",user_id: "1002",nickname: "相忘于江湖",create_time: new Date("2019-08-05T22:08:15.522Z"),like_number: NumberInt(1000),state: "1"},{_id: "2",article_id: "100001",content: "我夏天空腹喝凉开水,冬天喝温开水",user_id: "1005",nickname: "伊人憔悴",create_time: new Date("2019-08-05T23:58:51.485Z"),like_number: NumberInt(888),state: "1"},{_id: "3",article_id: "100001",content: "我一直喝凉开水,冬天夏天都喝。",user_id: "1004",nickname: "杰克船长",create_time: new Date("2019-08-06T01:05:06.321Z"),like_number: NumberInt(666),state: "1"},{_id: "4",article_id: "100001",content: "专家说不能空腹吃饭,影响健康。",user_id: "1003",nickname: "凯撒",create_time: new Date("2019-08-06T08:18:35.288Z"),like_number: NumberInt(2000),state: "1"},{_id: "5",article_id: "100001",content: "研究表明,刚烧开的水千万不能喝,因为烫嘴。",user_id: "1003",nickname: "凯撒",create_time: new Date("2019-08-06T11:01:02.521Z"),like_number: NumberInt(3000),state: "1"}]);
} catch (e) {print(e);
};

3.4 查询文档

查询文档的语法格式如下

db.collection.find(query, projection)
参数类型描述
db数据库实例指定当前的数据库实例
collection字符串指定要查询的集合名称
query文档可选,指定查询条件的文档。如果省略,则返回集合中的所有文档
projection文档可选,指定要在结果文档中返回的字段。如果省略,则返回所有字段

3.4.1 查询所有文档

db.comment.find();

每条文档会有一个叫 _id 的字段,这个相当于我们原来关系数据库中表的主键,如果在插入文档记录时没有指定该字段,MongoDB 会自动创建,其类型是 ObjectID 类型

3.4.2 条件查询

如果想按一定条件来查询,比如查询 user_id 为 1003 的记录,只要在 find() 中添加参数即可,参数也是 json 格式

db.comment.find({user_id:'1003'})

如果只需要返回符合条件的第一条数据,我们可以使用 findOne 命令来实现,语法和 find 一样

例如查询用户编号是 1003 的记录,但只最多返回符合条件的第一条记录

db.comment.findOne({user_id:'1003'})

3.4.3 投影查询

如果要查询结果返回部分字段,则需要使用投影查询(不显示所有字段,只显示指定的字段)

例如查询结果只显示 _id、userid、nickname 字段

db.comment.find({user_id: "1003"}, {userid: 1, nickname: 1})

默认 _id 字段会显示,可以隐藏 _id 字段

db.comment.find({user_id: "1003"}, {userid: 1, nickname: 1, _id: 0})

3.5 文档的更多查询

3.5.1 正则的复杂条件查询(模糊查询)

db.集合.find({字段:/正则表达式/})

正则表达式是 js 的语法,直接量的写法


查询评论内容包含 开水 的所有文档

db.comment.find({content:/开水/})

查询评论的内容中以 专家 开头的文档

db.comment.find({content:/^专家/})

3.5.2 比较查询

查询大于特定值的文档

db.集合名称.find({ "field" : { $gt: value }})

查询小于特定值的文档

db.集合名称.find({ "field" : { $lt: value }})

查询大于等于特定值的文档

db.集合名称.find({ "field" : { $gte: value }})

查询小于等于特定值的文档

db.集合名称.find({ "field" : { $lte: value }})

查询不等于特定值的文档

db.集合名称.find({ "field" : { $ne: value }})

查询评论点赞数量大于 700 的记录

db.comment.find({like_number: {$gt: 700}
});

3.5.3 包含查询

包含使用 $in 操作符

查询评论的集合中 user_id 字段包含 1003 或 1004 的文档

db.comment.find({user_id: {$in: ["1003", "1004"]}
})

不包含使用 $nin 操作符

查询评论的集合中 user_id 字段不包含 1003 或 1004 的文档

db.comment.find({user_id: {$nin: ["1003", "1004"]}
})

3.5.4 条件连接查询

我们如果需要查询同时满足两个以上条件,需要使用 $and 操作符将条件进行关联(相当于 SQL 的 and)

$and:[ { },{ },{ } ]

查询评论集合中 like_number 大于等于 700 并且小于等于 2000 的文档

db.comment.find({$and: [{ like_number: { $gte: NumberInt(700) } },{ like_number: { $lte: NumberInt(2000) } }]
})

如果两个以上条件之间是或者的关系,我们使用 $or 操作符进行关联,与前面 $and 的使用方式相同

$or:[ { },{ },{ } ]

查询评论集合中 user_id 为 1003,或者点赞数小于 1000 的文档记录

db.comment.find({$or: [{ user_id: "1003" },{ like_number: { $lt: 1000 } }]
})

3.6 分页列表查询

可以使用 limit() 方法来读取指定数量的数据,使用 skip() 方法来跳过指定数量的数据

db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)
参数名描述是否必需数据类型
COLLECTION_NAME要查询的集合名称字符串
.find()查询操作,返回集合中的文档
.limit(NUMBER)限制返回文档的数量整数
.skip(NUMBER)跳过指定数量的文档,并返回余下的文档整数
db.comment.find().skip(2).limit(2)

3.7 排序查询

sort() 方法对数据进行排序,sort() 方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而 -1 用于降序排列

db.COLLECTION_NAME.find().sort({KEY:ORDER})
参数名描述是否必需数据类型可能的值
KEY用于排序的字段名称字符串任何有效的字段名
ORDER排序的方向数字1 (升序), -1 (降序)

对 user_id 降序排列,并对点赞量进行升序排列

db.comment.find().sort({user_id: -1,like_number: 1});

3.8 查询的执行顺序

skip()、limilt()、sort() 三个放在一起执行的时候,执行的顺序是先 sort()、skip()、limit(),和命令编写顺序无关

3.9 文档更新

3.9.1 更新集合中的第一个匹配的文档

db.collection.updateOne(<filter>,<update>,{upsert: <boolean>,writeConcern: <document>,collation: <document>,arrayFilters: [<filterdocument1>, ...]}
);
参数名描述类型必需
filter指定更新操作的目标文档的条件document
update指定更新操作的内容,可以使用更新操作符document
upsert如果没有文档符合filter条件,是否插入一个新文档。默认为falseboolean
writeConcern指定写入操作的关心级别document
collation指定用于操作的排序规则document
arrayFilters用于指定数组字段上的过滤条件,适用于更新数组字段中的元素array of filter documents
3.9.1.1 覆盖修改(了解即可)

值得注意的是,在高版本的 MongoDB 中,覆盖修改似乎已经被禁掉了,执行后会直接报错

如果我们想修改 _id 为 1 的记录,将该记录的点赞量修改为 1001,输入以下语句:

db.comment.updateOne({ _id: "1" },{ like_number: NumberInt(1001) }
);

执行后,我们会发现,这条文档除了 like_number 字段其它字段都不见了

3.9.1.2 局部修改

为了解决这个问题,我们需要使用修改器 $set 来实现

我们修改 _id 为 2 的记录,将点赞量改为 2222

db.comment.updateOne({ _id: "2" },{$set: {like_number: 2222}}
);

3.9.2 批量更新

db.collection.updateMany(<filter>,<update>,{upsert: <boolean>,writeConcern: <document>,collation: <document>,arrayFilters: [<filterdocument1>, ...]}
);
参数名描述类型是否必需
filter定义要更新文档的查询条件。这是MongoDB用来确定哪些文档应该被更新的依据document
update指定更新操作的内容,可以包含更新操作符,如$set$inc等,用于修改文档的字段document
upsert当设置为true时,如果filter没有匹配到任何文档,则根据filterupdate创建一个新的文档。默认值为falseboolean
writeConcern指定本次更新操作的写入关心级别,用于确认数据写入到数据库的安全程度document
collation定义更新的排序规则,用于指定如何比较字符串。这对于实现特定的语言排序规则很有用document
arrayFilters当更新操作需要针对数组中的特定元素时,可以使用arrayFilters来指定过滤条件,这样就可以更新数组字段中的部分元素array of filter documents

更新所有用户为 1003 的用户的昵称为凯撒大帝

db.comment.updateMany({ user_id: "1003" },{$set: {nickname: "凯撒大帝"}}
);

MongoDB 返回的结果

{acknowledged: true,insertedId: null,matchedCount: 2,modifiedCount: 0,upsertedCount: 0
}

3.9.3 列值增长的修改

如果我们想实现对某列值在原有值的基础上进行增加或减少,可以使用 $inc 运算符来实现

例如,让 3 号数据的点赞自增一个单位

db.comment.updateOne({ _id: "3" },{$inc: {like_number: NumberInt(1)}}
);

3.10 删除文档

3.10.1 删除集合中匹配到的第一个文档

db.collection.deleteOne(<query>,{writeConcern: <document>}
)
参数类型必填描述
<query>document指定删除条件,用于匹配集合中的文档。如果不指定,则默认匹配所有文档
writeConcerndocument指定写操作的关心级别,用于确认写操作的成功级别。例如,可以指定数据写入到多少个副本集成员后才算成功
  • <query> 参数是一个文档,它定义了删除操作的条件。只有满足这些条件的第一个文档会被删除
  • writeConcern 参数是一个可选的文档,用于指定写操作的确认级别。例如,可以设置 w: "majority" 来确保写操作在大多数副本集成员上成功后才返回。如果不指定,则使用默认的写关注级别

删除 _id 为 1 的记录

db.comment.deleteOne({ _id: "1" }
);

3.10.2 删除所有匹配到的文档

db.collection.deleteMany(<query>,{writeConcern: <document>}
)
参数类型必填描述
<query>document指定删除条件,用于匹配集合中的文档。如果不指定,则默认匹配所有文档,这将删除集合中的所有文档
writeConcerndocument指定写操作的关心级别,用于确认写操作的成功级别。例如,可以指定数据写入到多少个副本集成员后才算成功
  • <query> 参数是一个文档,它定义了删除操作的条件。所有满足这些条件的文档都会被删除
  • writeConcern 参数是一个可选的文档,用于指定写操作的确认级别。例如,可以设置 w: "majority" 来确保写操作在大多数副本集成员上成功后才返回。如果不指定,则使用默认的写关注级别

删除点赞量大于等于 3000 的评论

db.comment.deleteMany({ like_count: { $gte: 3000 } }
);

3.11 统计查询

  • count() 方法在 MongoDB 中也可以用来统计集合中的文档数量
  • 但是 count() 方法已经被官方标记为废弃(deprecated),并且在未来的版本中可能会被移除
  • 尽管如此,它仍然在当前的 MongoDB 版本中可用

统计查询使用 countDocuments() 方法,语法如下:

db.collection.countDocuments(query, options)
参数名描述类型是否必需
query指定用于过滤文档的条件。如果没有指定,则计数集合中的所有文档document or object
options为计数操作指定额外的选项document or object

下面是 options 参数的一些常见选项及其描述:

选项名描述类型是否必需
limit指定要计数的最大文档数量。如果设置,则计数操作会在达到这个限制后停止integer
skip指定计数前要跳过的文档数量integer
hint指定索引来执行计数操作。如果指定,MongoDB会使用这个索引而不是查询优化器选择的索引string
maxTimeMS指定操作的最大执行时间(毫秒)。如果操作超过这个时间,MongoDB会终止操作integer
readConcern指定查询的读取关注级别string
collation指定用于操作的排序规则document

3.11.1 统计所有记录数

db.comment.countDocuments()

3.11.2 按条件统计记录数

统计 user_id 为 1003 的记录条数

db.comment.countDocuments({user_id: "1003"}
);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/477031.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MYSQL——多表设计以及数据库中三种关系模型

大致介绍数据库中三种关系模型 一对多&#xff08;1:N&#xff09; 定义&#xff1a; 一个实体可以与另一个实体的多个实例相关联&#xff0c;而后者只能与前者的一个实例相关联。 例子&#xff1a; 学生和课程的关系。 学生&#xff08;1&#xff09;&#xff1a;每个学生…

企业网页设计的安全与数据保护

企业网页设计不仅要考虑美观和功能性&#xff0c;安全与数据保护也是重中之重。在这个信息爆炸的时代&#xff0c;用户的数据隐私和安全问题日益凸显&#xff0c;企业必须采取多种措施来保障用户的信息安全。 首先&#xff0c;**SSL加密**是基础中的基础。通过使用SSL证书&…

观察者模式和订阅模式

观察者模式和订阅模式在概念上是相似的&#xff0c;它们都涉及到一个对象&#xff08;通常称为“主题”或“发布者”&#xff09;和多个依赖对象&#xff08;称为“观察者”或“订阅者”&#xff09;之间的关系。然而&#xff0c;尽管它们有相似之处&#xff0c;但在某些方面也…

logback动态获取nacos配置

文章目录 前言一、整体思路二、使用bootstrap.yml三、增加环境变量四、pom文件五、logback-spring.xml更改总结 前言 主要是logback动态获取nacos的配置信息,结尾完整代码 项目springcloudnacosplumelog&#xff0c;使用的时候、特别是部署的时候&#xff0c;需要改环境&#…

工具学习_Docker

0. Docker 简介 Docker 是一个开源平台&#xff0c;旨在帮助开发者构建、运行和交付应用程序。它通过容器化技术将应用程序及其所有依赖项打包在一个标准化的单元&#xff08;即容器&#xff09;中&#xff0c;使得应用程序在任何环境中都能保持一致的运行效果。Docker 提供了…

基础知识学习上

基础知识学习上 1.关于print1.1 format 方法 2.运算符2.1 除法运算2.2 幂运算 3.条件控制语句3.1 if语句3.2 循环语句 4.复杂数据类型4.1列表4.2字典4.3字符串 5.函数 1.关于print 分隔符 print(1, 2, 3, 4, sep-) print(1, 2, 3, 4, sep。)结尾符 print(1, 2, 3, 4, end?) pr…

无监督跨域目标检测的语义一致性知识转移

Semantic consistency knowledge transfer for unsupervised cross domain object detection 无监督跨域目标检测的语义一致性知识转移 作者: Zichong Chen, Ziying Xia, Xiaochen Li, Junhao Shi, Nyima Tashi, Jian Cheng 所属机构: 电子科技大学信息与通信工程学院&…

AI智能稿件排版系统订单管理系统

在现代制造业和服务行业中&#xff0c;高效的生产流程和精确的订单管理是企业保持竞争优势的核心要素。AI智能稿件排版系统和订单管理系统作为一体化解决方案&#xff0c;以其强大的自动化能力和智能化技术&#xff0c;帮助企业实现排版效率提升、数据格式兼容性增强和生产流程…

Android Google登录接入

官方文献&#xff1a; 1、前期准备&#xff1a; https://developers.google.cn/identity/sign-in/android/legacy-start-integrating?hlzh-cnhttps://developers.google.cn/identity/sign-in/android/legacy-start-integrating?hlzh-cn 2、具体开发&#xff1a; 新版 Googl…

论文浅尝 | MindMap:知识图谱提示激发大型语言模型中的思维图(ACL2024)

笔记整理&#xff1a;和东顺&#xff0c;天津大学硕士&#xff0c;研究方向为软件缺陷分析 论文链接&#xff1a;https://aclanthology.org/2024.acl-long.558/ 发表会议&#xff1a;ACL 2024 1. 动机 虽然大语言模型&#xff08;LLMs&#xff09;已经在自然语言理解和生成任务…

Spring Cloud Data Flow快速入门Demo

1.什么是Spring Cloud Data Flow&#xff1f; Spring Cloud Data Flow 是一个用于构建和编排数据处理流水线的云原生框架。它提供了一种简化的方式来定义、部署和管理数据处理任务和流应用程序。以下是一些关键特性和组件&#xff1a; 关键特性 流处理&#xff1a; 支持实时数…

C# .NET环境下调用ONNX格式YOLOV8模型问题总结

我的环境是&#xff1a; Visual Studio: 2019 显卡&#xff1a; 一、遇到问题 1、EntryPointNotFoundException:无法在DLL“onnxruntime”中找到名为“OrtGetApiBase”的入口点。差了下原因&#xff0c;入口点是启动项中的问题。 原因&#xff1a;之前用yolov7时安装的版本在C…

量子感知机

神经网络类似于人类大脑&#xff0c;是模拟生物神经网络进行信息处理的一种数学模型。它能解决分类、回归等问题&#xff0c;是机器学习的重要组成部分。量子神经网络是将量子理论与神经网络相结合而产生的一种新型计算模式。1995年美国路易斯安那州立大学KAK教授首次提出了量子…

AI Large Language Model

AI 的 Large Language model LLM , 大语言模型&#xff1a; 是AI的模型&#xff0c;专门设计用来处理自然语言相关任务。它们通过深度学习和庞大的训练数据集&#xff0c;在理解和生成自然语言文本方面表现出色。常见的 LLM 包括 OpenAI 的 GPT 系列、Google 的 PaLM 和 Meta…

运维团队3D可视化智能机房管理方案

随着信息技术的飞速发展&#xff0c;机房作为信息技术基础设施的核心部分&#xff0c;其管理效率与可视化程度对运维团队的工作质量有着直接影响。本文将介绍一种结合3D可视化技术的机房管理方案&#xff0c;为运维团队提供一种新的视角和工具&#xff0c;以提升机房管理的效率…

CKA认证 | Day2 K8s内部监控与日志

第三章 Kubernetes监控与日志 1、查看集群资源状态 在 Kubernetes 集群中&#xff0c;查看集群资源状态和组件状态是非常重要的操作。以下是一些常用的命令和解释&#xff0c;帮助你更好地管理和监控 Kubernetes 集群。 1.1 查看master组件状态 Kubernetes 的 Master 组件包…

111 - Lecture 10

File I/O and GUI with JavaFX 文件输入/输出与JavaFX图形用户界面 一、Overview 1. File I/O &#xff08;1&#xff09; learning Java File I/O mechanism &#xff08;2&#xff09; writing into and reading from a file 使用文件I/O进行数据读取和…

分享一下arr的意义(c基础)(必看)(牢记)

arr 即数组名 一般指数组首元素地址 在两种情况下不是 1&#xff1a;sizeof&#xff08;arr&#xff09; arr指整个数组简单讲解一下strlen与sizeof&#xff08;c基础&#xff09;_strzeof在c语言中什么意思-CSDN博客 2&#xff1a;printf&#xff08;"%p",&…

大数据基于Spring Boot的化妆品推荐系统的设计与实现

摘 要 随着大数据时代的到来&#xff0c;人们对于个性化服务的需求越来越高。化妆品推荐系统作为一个认知智能模型段&#xff0c;在为消费者提供更好的购物体验方面发挥了重要作用。本研究基于大数据技术设计了一个高效准确的化妆品推荐系统。通过对海量数据的分析和处理&…

NUXT3学习日记四(路由中间件、导航守卫)

前言 在 Nuxt 3 中&#xff0c;中间件&#xff08;Middleware&#xff09;是用于在页面渲染之前或导航发生之前执行的函数。它们允许你在路由切换时执行逻辑&#xff0c;像是身份验证、重定向、权限控制、数据预加载等任务。中间件可以被全局使用&#xff0c;也可以只在特定页…