ElasticSearch基础-快速上手
MySql是关系型数据库,ES是文档型数据库,他们有一些相同的概念,只是叫法不一样。
settings是关于索引的设置,mappings定义索引的映射(表结构)。
2. 删除、关闭、打开索引
3. 为索引创建别名
1.查看映射
2.扩展映射
只能新增、不能修改。
3.基础数据类型
keyword: 不进行分词,对应term精准查询
text:分词,建立倒排索引,对应math搜索、如果使用term是无法搜索出数据的。
数值类型:byte、short、integer、long、float、double、half_float、scaled_float、
unsigned_long,对应term搜索和range搜索。
boolean:布尔类型
date:日期类型
4.复杂数据类型
普通对象:通常用在一对一关系场景。
内嵌对象:通常用在一对多关系场景、而且有内嵌对象条件查询的场景。
父子关系:通常用在父子文档更新很频繁,可以只更新父文档或只更新子文档的场景。
地理类型:地理查询
1.单个创建
2.批量创建
3.单个更新
4.批量更新
5.根据条件更新
6.upsert
存在则用doc内容去更新,不存在则用upsert内容去创建
7.单个删除
8.批量删除
9.根据条件删除
如何设置数据库 当字段不存在自动创建?
创建表格,使用username作为主键(建议字段名使用“username”),票数设置默认值为1:def***lt 1(使用了默认值之后插入时就不要指定这个字段了,因为如果你使用null插入新数据,新纪录的票数字段就会是null,而不是默认值1)
使用 ON DUPLICATE KEY UPDATE指令实现 upsert(存在则更新)操作:
执行结果:
Append 流、 Retract 流、 Upsert 流、动态表
Append-only 流: 仅通过 INSERT 操作修改的动态表可以通过输出插入的行转换为流。
Retract 流: retract 流包含两种类型的 message: add messages 和 retract messages 。通过将INSERT 操作编码为 add message、将 DELETE 操作编码为 retract message、将 UPDATE 操作编码为更新(先前)行的 retract message 和更新(新)行的 add message,将动态表转换为 retract 流。下图显示了将动态表转换为 retract 流的过程
Upsert 流: upsert 流包含两种类型的 message: upsert messages 和delete messages。转换为 upsert 流的动态表需要(可能是组合的)唯一键。通过将 INSERT 和 UPDATE 操作编码为 upsert message,将 DELETE 操作编码为 delete message ,将具有唯一键的动态表转换为流。消费流的算子需要知道唯一键的属性,以便正确地应用 message。与 retract 流的主要区别在于 UPDATE 操作是用单个 message 编码的,因此效率更高
Dynamic Tables
Dynamic Tables翻译
如何删除MongoDB数据库中的文件
一、Insert操作
Insert操作是MongoDB插入数据的基本方法,对目标集合使用Insert操作,会将该文档添加到MongoDB并自动生成相应的ID键。文档结构采用类似JSON的BSON格式。常见的插入操作主要有单条插入和批量插入两种形式。插入时只是简单地将文档存入数据库中,不进行额外的验证,也不会执行代码,所以不存在注入式攻击的可能。
1、单条插入
2、批量插入
MongoDB对批量插入的支持是通过传递多个文档组成的数组到数据库来实现的。由于它插入数据是通过发送TCP请求的,这样只需发送单个TCP请求,且数据库无需处理大量的消息头,减少插入时间。这种方式的批量插入一次只能将多个文档插入到一个集合中,对于插入到多个集合可以循环调用Insert操作。
二、Remove操作
remove函数可以用来删除数据,能接受一个文档作为可选参数,只有符合条件的文档才会被删除。删除数据是永久性的,不能撤销,也不能恢复,需要谨慎。删除文档需要清空整个集合,不如直接删除集合快。
三、Update操作
update函数用于修改数据库中的数据,接收两个参数,一个是查询文档,用来查找要更新的文档,另一个是修改器文档,用来描述对找到的文档做哪些修改。更新操作是原子性的,如果多个更新同时发生,则所有的更新都会执行,但最后的更新是最终赢家。
1、整体更新(文档替换)
2、局部更新(修改器)
部分更新是通过原子的更新修改器实现的,使用修改器时除了”_id“的值不能改变,其他任何值都能改变。文档替换是可以改变所有值的。
$inc修改器:将指定属性的值增加特定的步长,如果键不存在则创建。
$set修改器:用来指定一个键的值,如果不存在则创建。
$push:数组修改器,如果指定的键存在,则向已有的数组末尾加入一个元素,键不存在则会创建一个新的数组。
3、upsert操作
upsert操作具有saveOrUpdate的功能,如果没有文档符合更新条件,则以更新条件和更新文档为基础创建一个新的文档。如果有符合更新条件的文档,则正常更新。创建新文档时会以条件文档作为基础,将修改器作用其之上。upsert操作是原子性的,高效的。
四、瞬间完成
上面的插入,删除和更新操作都是瞬间完成的,不需要等待数据库响应。这样的实现可以获取高性能,速度非常快,只会受客户端发送速度和网络速度的制约。但由于不会获取服务器状态,所以不能保证操作顺利完成。这对于付费系统,安全性较高的系统是不可行的,此时对这些操作需要使用的安全版本。安全版本会在操作执行后立即运行getLastError命令,来检查是否执行成功。如果失败一般会抛出可捕获的异常,然后可以在代码中处理。
mysql实现upsert功能
可以在INSERT INTO…..后面加上 ON DUPLICATE KEY UPDATE方法来实现。如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE。
例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果:
如果行作为新记录***入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。
注释:如果列b也是唯一列,则INSERT与此UPDATE语句相当:
关于upsert和UPSERT一次最多能更新多少条主表单数据?的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。