DefaultResultSetHandler对返回结果进行处理在 Mybatis 中 ResultSetHandler 接口用于在 StatementHandler 对象执行完查询操作或存储过程后,对结果集或存储过程的执行结果进行处理...,如下图图片可以看出,Mybatis 先创建 DefaultResultHandler 对象,接着放入 handleRowValues() 方法中,该方法会把数据库查询返回的多条记录转换为 resultMap...,(划重点)由此可见,**Mybatis** 返回集合类型默认是空集合handlerResult(ResultContext空集合在 handleRowValues() 方法中,处理返回记录,转换为...总结由上经过源码分析,我们知道 Mybatis 返回集合类型默认是空集合,我们在日常开发中,对于 Mybatis 返回集合类型不需要判断是否为 null,直接调用 list.size() > 0 或者其他第三方工具包提供的集合判空方法即可
看完这篇你就知道查询结果为空时候为什么集合会是空集合而不是 NULL,而对象为什么会是 NULL 了。 PS:对过程不感兴趣的可以直接跳到最后看结论。...那么我们看到 DefaultSqlSession#selectList() 方法,先说结论:返回值为空集合而不是 NULL。...只不过 selectList 是直接把 executor.query 从 defaultResultHandler.getResultList() 返回的空集合没有做处理,直接返回。...如果返回值是 Java 集合类型,如 List、Map,会先初始化(new 一个集合对象),再把结果添加进去;如果返回值是普通对象,查询不到时,返回值是 null。...而返回值为集合对象且查为空时,selectList 会把这个存储结果的 List 对象直接返回,此时这个 List 就是个空集合。
DefaultResultSetHandler对返回结果进行处理 在 Mybatis 中 ResultSetHandler 接口用于在 StatementHandler 对象执行完查询操作或存储过程后,...,如下图 image.png 可以看出,Mybatis 先创建 DefaultResultHandler 对象,接着放入 handleRowValues() 方法中,该方法会把数据库查询返回的多条记录转换为...,(划重点)由此可见,Mybatis 返回集合类型默认是空集合 • handlerResult(ResultContext空集合 2....总结 由上经过源码分析,我们知道 Mybatis 返回集合类型默认是空集合,我们在日常开发中,对于 Mybatis 返回集合类型不需要判断是否为 null,直接调用 list.size() > 0 或者其他第三方工具包提供的集合判空方法即可
返回map类型 1. xml中 2.Dao接口中 Map... selectUser(); 返回List类型 3. xml中 2.Dao接口中 List selectUser(); 返回List>类型 <select id="selectUser
private String categroy; private String level; private Integer gradeldId; //关联主表id } 2.创建返回类...Dto 用来接收查询出来的结果 @Data public class ResultDto { private Integer id; private String name;...private String address; private List teacherList; } 3.重点:然后配置xml //集合就是用...常用的属性就不说了,特别要注意的是ofType这个要指向各自表的实体类,然后子表的column属性不要和主表重名,一旦重名就会出问题,不知道是不是我配置的问题,希望有大佬指教,反正不重名就可以 接下来就是查询语句了...z_test_grade ztg LEFT JOIN z_test_teacher ztt ON ztt.gradeld_id = ztg.id 5.返回结果数据
1.业务背景 业务场景中,一个会话中存在多个场景,即一个session_id对应多个scene_id和scene_name 如果你写成如下的聚合模型类 public class SceneVO { private...String sessionId; private String sceneId; private String sceneName; // 省略对应的getter和setter方法 } 返回的...ofType:集合存放的类型,List集合要装的类的类名,这里是SubSceneVO --> 返回的是SceneVO对象,SceneVO对象有一个List装着SubSceneVO --> 集合的变量名,这里SceneVO类里的List变量名为sceneList ofType属性:集合存放的类型,List集合要装的类的类名,这里是SubSceneVO
在 MongoDB 中,数据库和集合都不需要手动创建,当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建数据库和集合。...可以将对象或数组中的对象添加进集合中,添加时如果集合或数据库不存在,会自动创建。 插入的文档对象会默认添加_id 属性,这个属性对应一个唯一的id,是该文档的唯一标识。...; // 删除集合(性能好),集合不存在 删除数据库 db.dropDatabase() 数据库中的数据一般不会删除,所以删除方法一般不用。 ...db.users.remove({}); // 删除所有的文档对象(即清空集合,性能略差),集合还在 db.users.drop(); show dbs; // 17.向 numbers 中插入...查询的方法: Model.find(conditions, [projection], [options], [callback]) - 查询所有符合条件的文档,总会返回一个数组
创建集合 创建集合分为两步,-是对对集合设定规则,二是创建集合,创建mongoose.Schema构造函数的实例即可创建集合。...= mongoose.model ('Course', courseSchema); //第一个参数是集合名称,第二个是集合规则。...4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档) Course.find().then(result => console.log(result)) //...通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的 要查询文章的所有信息包括发表用户,就需要用到集合关联。...使用id对集合进行关联 使用populate方法进行关联集合查询 ?
}) #mongoose基本使用 #mongoose的几个新的对象 在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。...同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。...mongoose中任何任何事物都是从Schema开始的。每一个Schema对应MongoDB中的一个集合(collection)。Schema中定义了集合中文档(document)的样式。...#创建model(集合) let personModel= mongoose.model('person', personSchema); person:数据库中的集合名称,当我们对其添加数据时如果person...已经存在,则会保存到其目录下,如果未存在,则会创建person集合,然后在保存数据。
,但宝宝不说 ?...每个 schema 映射到 MongoDB 的集合(collection)和定义该集合(collection)中的文档的形式。...字段不存在的文档Model.find( { age: { not: { lte: 24 }}})字段相关操作符符号描述exists匹配存在指定字段的文档type返回字段属于指定类型的文档数组字段的查找符号描述...sort:如果查询条件找到多个文档,则设置排序顺序以选择要更新哪个文档。 maxTimeMS:为查询设置时间限制。 upsert:布尔值,如果对象不存在,则创建它。默认值为 false。...看完Models,最后让我们来看下在实战中比较有用的Populate 联表(Populate) Mongoose 的 populate() 可以连表查询,即在另外的集合中引用其文档。
1.创建集合 创建集合分为两步,-是对对集合设定规则,二是创建集合,创建mongoose.Schema构造函数的实例即可创建集合。...= mongoose.model ('Course', courseSchema); //第一个参数是集合名称,第二个是集合规则。...在项目根目录下输入以下命令导入 mongoimport -d 数据库名称 -c 集合名称 --file 要导入的数据文件 4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档...通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的 要查询文章的所有信息包括发表用户,就需要用到集合关联。...使用id对集合进行关联 使用populate方法进行关联集合查询 // 关联集合 const mongoose = require('mongoose'); // 连接数据库 mongoose.connect
5、mongoose验证 在创建集合规则时,可以设置当前字段的验证规则,验证失败就则输入插入失败。...author: { type: String, validate: { validator: v => { // 返回布尔值...通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。...使用id对集合进行关联 使用populate方法进行关联集合查询 集合关联实现 // 用户集合 const User = mongoose.model('User', new mongoose.Schema...title: { type: String }, // 使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId
内嵌是把相关联的数据保存在同一个文档内,我们可以用对象或数组的形式来存储,这样好处是我们可以在一个单一操作内完成,可以发送较少的请求到数据库服务端,但是这种内嵌类型也是一种冗余的数据模型,会造成数据的重复...$lookup.foreignFiled: 被 Join 的集合的字段,本示例中是 Books 表的 bookId 字段。 $as: 别名,关联查询返回的这个结果起一个新的名称。...如果需要指定哪些字段返回,哪些需要过滤,可定义 $project 对象,关联查询的字段过滤可使用 别名.关联文档中的字段 进行指定。...Virtual 和 populate 实现 Mongoose 的 populate 方法默认情况下是指向的要关联的集合的 _id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose...表示的要 Join 的集合的名称,同 $lookup.from justOne: 默认为 false 返回多条数据,如果设置为 true 就只会返回一条数据 AuthorSchema.virtual('
/user.json(导入文件) 查询文档 // 引入mongoose第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect..., hobbies: [String] }); // 使用规则创建集合 const User = mongoose.model('User', userSchema); // 查询用户集合中的所有文档...默认返回当前集合中的第一条文档 // User.findOne({name: '李四'}).then(result => console.log(result)) // 查询用户集合中年龄字段大于20...并且小于40的文档 // User.find({age: {$gt: 20, $lt: 40}}).then(result => console.log(result)) // 查询用户集合中hobbies...// 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete({_id: '5c09f267aeb04b22f8460968'}
,存储和操作的内容都是文档 字段 文档中的一条数据,属性名就是字段名 数据库和集合都不需要手动创建 当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建 7 安装可视化工具 下载地址...集合名>.findOne({}) 用来查询集合中符合条件的第一个文档 db.集合名>.find({}).count() 查询所有结果的数量 修改集合中符合条件的文档 db....集合名>.update({查询条件},{新对象},{配置}) 默认只修改一个 db.集合名>.updateOne({查询条件},{新对象}) 修改一个符合条件的文档 db....集合名>.updateMany({查询条件},{新对象}) 同时修改多个符合条件的文档 db....查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof
字段 文档中的一条数据,属性名就是字段名 数据库和集合都不需要手动创建 当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建 7 安装可视化工具 下载地址:https://www.mongodbmanager.com...集合名>.find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db.集合名>.findOne({}) 用来查询集合中符合条件的第一个文档 db....集合名>.find({}).count() 查询所有结果的数量 修改集合中符合条件的文档 db.集合名>.update({查询条件},{新对象},{配置}) 默认只修改一个 db....集合名>.updateOne({查询条件},{新对象}) 修改一个符合条件的文档 db.集合名>.updateMany({查询条件},{新对象}) 同时修改多个符合条件的文档 db....查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof
1.MongoDB增删改查操作 1.1 创建集合 创建集合分为两步,一是对对集合设定规则,二是创建集合,创建mongoose.Schema构造函数的实例即可创建集合。...1.7 集合关联 通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。...使用id对集合进行关联 使用populate方法进行关联集合查询 ?...集合关联实现 // 用户集合 const User = mongoose.model('User', new mongoose.Schema({ name: { type: String } }));...使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId, ref: 'User' } })); //联合查询 Post.find
3、查找文档 // 根据条件查找文档(条件为空则查找所有文档) Course.find().then(result => console.log(result)) // 返回文档集合 [{...: String, hobbies: [String] }); // 使用规则创建集合 const User = mongoose.model('User', userSchema); //...查询用户集合中的所有文档 // User.find().then(result => console.log(result)); // 通过_id字段查找文档 // User.find({_id: '...5c09f267aeb04b22f8460968'}).then(result => console.log(result)) // findOne方法返回一条文档 默认返回当前集合中的第一条文档 /...({age: {$gt: 20, $lt: 40}}).then(result => console.log(result)) // 2.查询用户集合中hobbies字段值包含足球的文档 // User.find
: String, hobbies: [String] }); // 使用规则创建集合 const User = mongoose.model('User', userSchema); //...查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete({_id: '5c09f267aeb04b22f8460968...}, {要修改的值}).then(result => console.log(result)) // 更新多个 User.updateMany({查询条件}, {要更改的值}).then(result...: String, hobbies: [String] }); // 使用规则创建集合 const User = mongoose.model('User', userSchema); //...找到要删除的文档并且删除 // 返回是否删除成功的对象 // 如果匹配了多条文档, 只会删除匹配成功的第一条文档 // User.updateOne({name: '李四'}, {age: 120, name
/model/connect"); 9.在 model 文件夹下新建 user.js 用来创建用户集合 //创建用户集合 //引入mongoose模块 const mongoose = require(..."mongoose"); const { Schema, model } = mongoose; //设定集合规则 const userSchema = new Schema({ account.../model/user.js"); //匹配二级请求路径 注册接口 register.post("/register", async (req, res) => { // 数据库中查询用户是否存在...中测试结果如下 可以成功返回插入的数据 13.在 app.js 中配置 cors 解决跨域问题 //引入cors模块 用来解决跨域问题 const cors = require('cors')...//注册接口 register.post("/register", async (req, res) => { // 数据库中查询用户是否存在 const user = await User.findOne
领取专属 10元无门槛券
手把手带您无忧上云