MySQL中记录(Documents)的基本操作——添加记录和查找记录

在MySQL中,我们通常不称数据表中的记录为“文档”,而是称之为“行”或“记录”。记录表示为JSON对象。在内部,它们以高效的二进制格式存储,从而实现快速查找和更新。

添加记录

使用add()方法可以将一个记录或记录列表插入到现有集合中。将以下记录插入countryinfo集合。由于这是多行内容,请按Enter键两次以插入记录。

mysql-js> db.countryinfo.add({GNP: .6,IndepYear: 1967,Name: "Sealand",Code: "SEA",demographics: {LifeExpectancy: 79,Population: 27},geography: {Continent: "Europe",Region: "British Islands",SurfaceArea: 193},government: {GovernmentForm: "Monarchy",HeadOfState: "Michael Bates"}}
)

该方法返回操作的状态。您可以通过搜索记录来验证操作。例如

mysql-js> db.countryinfo.find("Name = 'Sealand'")
{"GNP": 0.6,"_id": "00005e2ff4af00000000000000f4","Name": "Sealand","Code:": "SEA","IndepYear": 1967,"geography": {"Region": "British Islands","Continent": "Europe","SurfaceArea": 193},"government": {"HeadOfState": "Michael Bates","GovernmentForm": "Monarchy"},"demographics": {"Population": 27,"LifeExpectancy": 79}
}

除了添加记录时指定的字段外,还有一个字段_id。每个记录都需要一个名为_id的标识符字段。_id字段的值在同一集合中的所有记录中必须是唯一的。在MySQL 8.0.11及更高版本中,记录id是由服务器生成的,而不是由客户端生成的,因此MySQL Shell不会自动设置_id值。如果记录不包含_id字段,则8.0.11或更高版本的MySQL服务器会设置_id值。在这种情况下,8.0版本或5.7版本的MySQL服务器不会设置_id值,因此必须显式指定。如果不这样做,MySQL Shell将返回错误5115记录缺少一个必填字段。

查找记录

您可以使用find()方法从模式中的集合中查询和返回记录。MySQL Shell提供了额外的方法与find()方法一起使用,以过滤和排序返回的记录。

MySQL提供了以下运算符来指定搜索条件:OR(||)、AND(&&)、XOR、IS、NOT、BETWEEN、IN、LIKE、!=、<>、>、>=、<、<=、&、|、<<、>>、+、-、*、/、~、和 %。

查找集合中的所有记录

若要返回集合中的所有记录,请使用find()方法,而不指定搜索条件。例如,以下操作将返回countryinfo集合中的所有记录。

mysql-js> db.countryinfo.find()
[{"GNP": 828,"Code:": "ABW","Name": "Aruba","IndepYear": null,"geography": {"Continent": "North America","Region": "Caribbean","SurfaceArea": 193},"government": {"GovernmentForm": "Nonmetropolitan Territory of The Netherlands","HeadOfState": "Beatrix"}"demographics": {"LifeExpectancy": 78.4000015258789,"Population": 103000},...}]
240 documents in set (0.00 sec)

该方法生成的结果除了包含集合中的所有记录之外,还包含操作信息。

空集(没有匹配的记录)返回以下信息:

Empty set (0.00 sec)
筛选搜索

您可以使用find()方法包含搜索条件。所有表达式都必须用引号括起来。为了简洁起见,有些示例不显示输出。

一个简单的搜索条件可以由Name字段和一个我们知道在记录中的值组成。以下示例返回单个记录:

mysql-js> db.countryinfo.find("Name = 'Australia'")
[{"GNP": 351182,"Code:": "AUS","Name": "Australia","IndepYear": 1901,"geography": {"Continent": "Oceania","Region": "Australia and New Zealand","SurfaceArea": 7741220},"government": {"GovernmentForm": "Constitutional Monarchy, Federation","HeadOfState": "Elisabeth II"}"demographics": {"LifeExpectancy": 79.80000305175781,"Population": 18886000},}
]

以下示例搜索所有国民生产总值高于5000亿美元的国家。国家信息收集以百万为单位衡量国民生产总值。

mysql-js> db.countryinfo.find("GNP > 500000")
...[output removed]
10 documents in set (0.00 sec)

以下查询中的“人口”字段嵌入到人口统计对象中。要访问嵌入的字段,请使用人口统计和人口统计之间的时间段来确定关系。记录和字段名称区分大小写。

mysql-js> db.countryinfo.find("GNP > 500000 and demographics.Population < 100000000")
...[output removed]
6 documents in set (0.00 sec)

以下表达式中的算术运算符用于查询人均国民生产总值高于30000美元的国家。搜索条件可以包括算术运算符和大多数MySQL函数。

注意:countryinfo集合中有七个记录的总体值为零。因此,警告消息会出现在输出的末尾。

mysql-js> db.countryinfo.find("GNP*1000000/demographics.Population > 30000")
...[output removed]
9 documents in set, 7 warnings (0.00 sec)
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0
Warning (Code 1365): Division by 0

可以使用bind()方法将值与搜索条件分离。例如,不要指定硬编码的国家/地区名称作为条件,而是替换一个由冒号和以字母开头的名称(如国家/地区)组成的命名占位符。然后使用bind(占位符,value)方法,如下所示:

mysql-js> db.countryinfo.find("Name = :country").bind("country", "Italy")
{"GNP": 1161755,"_id": "00005de917d8000000000000006a","Code": "ITA","Name": "Italy","Airports": [],"IndepYear": 1861,"geography": {"Region": "Southern Europe","Continent": "Europe","SurfaceArea": 301316},"government": {"HeadOfState": "Carlo Azeglio Ciampi","GovernmentForm": "Republic"},"demographics": {"Population": 57680000,"LifeExpectancy": 79}
}
1 document in set (0.01 sec)

在程序中,绑定使您能够在表达式中指定占位符,这些占位符在执行前用值填充,并且可以从自动转义中受益(视情况而定)。

始终使用绑定对输入进行清理。避免在使用字符串串联的查询中引入值,这可能会产生无效输入,在某些情况下还会导致安全问题。

您可以使用占位符和bind()方法创建保存的搜索,然后使用不同的值调用这些搜索。例如,要创建已保存的国家/地区搜索:

mysql-js> var myFind = db.countryinfo.find("Name = :country")
mysql-js> myFind.bind('country', 'France')
{"GNP": 1424285,"_id": "00005de917d80000000000000048","Code": "FRA","Name": "France","IndepYear": 843,"geography": {"Region": "Western Europe","Continent": "Europe","SurfaceArea": 551500},"government": {"HeadOfState": "Jacques Chirac","GovernmentForm": "Republic"},"demographics": {"Population": 59225700,"LifeExpectancy": 78.80000305175781}
}
1 document in set (0.0028 sec)mysql-js> myFind.bind('country', 'Germany')
{"GNP": 2133367,"_id": "00005de917d80000000000000038","Code": "DEU","Name": "Germany","IndepYear": 1955,"geography": {"Region": "Western Europe","Continent": "Europe","SurfaceArea": 357022},"government": {"HeadOfState": "Johannes Rau","GovernmentForm": "Federal Republic"},"demographics": {"Population": 82164700,"LifeExpectancy": 77.4000015258789}
}1 document in set (0.0026 sec)
项目成果

您可以返回记录的特定字段,而不是返回所有字段。以下示例返回countryinfo集合中与搜索条件匹配的所有记录的GNP和Name字段。

使用fields()方法传递要返回的字段列表。

mysql-js> db.countryinfo.find("GNP > 5000000").fields(["GNP", "Name"])
[{"GNP": 8510700,"Name": "United States"}
]
1 document in set (0.00 sec)

此外,还可以通过表达式来描述想要返回的记录,并对这些返回的记录进行修改,比如添加、重命名、嵌套字段,甚至计算新的字段值。

例如,使用以下表达式更改字段的名称以仅返回两个记录。

mysql-js> db.countryinfo.find().fields(
mysqlx.expr('{"Name": upper(Name), "GNPPerCapita": GNP*1000000/demographics.Population}')).limit(2)
{"Name": "ARUBA","GNPPerCapita": 8038.834951456311
}
{"Name": "AFGHANISTAN","GNPPerCapita": 263.0281690140845
}
限制、排序和跳过结果

您可以应用limit()、sort()和skip()方法来管理find()方法返回的记录的数量和顺序。

要指定结果集中包含的记录数,请在find()方法后面附加一个值的limit()方法。以下查询返回countryinfo集合中的前五个记录。

mysql-js> db.countryinfo.find().limit(5)
... [output removed]
5 documents in set (0.00 sec)

若要对查询结果进行排序,可以在find()方法后附加sort()方法。你需要向sort()方法传递一个或多个字段名称的列表,用以指明排序的依据。同时,你还可以选择性地为每个字段指定排序方式,即升序(asc)或降序(desc)。若未明确指定,则默认采用升序排序。 

例如,以下查询按IndepYear字段对所有记录进行排序,然后按降序返回前八个记录。

mysql-js> db.countryinfo.find().sort(["IndepYear desc"]).limit(8)
... [output removed]
8 documents in set (0.00 sec)

limit()方法默认从集合中的第一个记录开始返回结果。如果你想改变起始的记录,可以使用skip()方法。例如,如果你想忽略第一个记录,并返回接下来符合条件的八个记录,你可以将1作为参数传递给skip()方法。

mysql-js> db.countryinfo.find().sort(["IndepYear desc"]).limit(8).skip(1)
... [output removed]
8 documents in set (0.00 sec)

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

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

相关文章

[C++基础]C++ 10个常用案例

1. Hello World 这是每个编程语言学习者都会遇到的第一个程序&#xff0c;用于展示如何在屏幕上打印“Hello, World!”。 #include<iostream> int main() { std::cout << "Hello, World!\n"; return 0; } 2. 变量声明与赋值 展示如何在C中声明…

打卡第7天-----哈希表

继续坚持✊,我现在看到leetcode上的题不再没有思路了,真的是思路决定出路,在做题之前一定要把思路梳理清楚。 一、四数相加 leetcode题目编号:第454题.四数相加II 题目描述: 给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j…

MVC拦截器、ThreadLocal来进行登录拦截

MVC拦截器、ThreadLocal来进行登录拦截 1. 对登录进行拦截1.1 什么是ThreadLocal1.2 定义UserHolder 类&#xff0c;来封装ThreadLocal方法1.3 拦截器WebMvcConfigurer 的配置1.4 登录的配置&#xff0c;当碰到拦截的方法的时候调用1.5 UserServiceImpl1.6 controller&#xff…

RoPE旋转位置编码从复数到欧拉公式

第二部分 从复数到欧拉公式 先复习下复数的一些关键概念 我们一般用表示复数&#xff0c;实数a叫做复数的实部&#xff0c;实数b叫做复数的虚部 复数的辐角是指复数在复平面上对应的向量和正向实数轴所成的有向角 的共轭复数定义为&#xff1a;&#xff0c;也可记作&#xff0…

分布式计算中的数据分片和副本机制

分布式计算中的数据分片和副本机制 在分布式计算中&#xff0c;数据分片&#xff08;Data Sharding&#xff09;是指将大量数据分割成较小的、独立的部分&#xff0c;每个部分存储在一个单独的节点或机器上。这种技术主要用于数据库系统中&#xff0c;比如哈希分区或范围分区&…

识别色带后执行相应命令

识别到红色和绿色色带后&#xff0c;会执行相应的命令以调整机器狗的行为&#xff0c;具体如下&#xff1a; 红色色带识别&#xff1a; 在 track 模式下&#xff0c;当识别到红色色带时&#xff0c;机器人会进入 divergeright 模式&#xff0c;表示机器人需要在接下来的行动中向…

AI发展的新方向:从卷模型到卷应用

在2024年7月4日于上海世博中心举办的世界人工智能大会暨人工智能全球治理高级别会议全体会议上&#xff0c;百度创始人、董事长兼首席执行官李彦宏发表了一段引人深思的演讲。他在产业发展主论坛上提出&#xff1a;“大家不要卷模型&#xff0c;要卷应用&#xff01;”这句话道…

刷题——序列化二叉树

序列化二叉树_牛客题霸_牛客网 char*传入&#xff0c;以 “!"分割&#xff0c;以"#"表示无 /* struct TreeNode {int val;struct TreeNode *left;struct TreeNode *right;TreeNode(int x) :val(x), left(NULL), right(NULL) {} }; */ class Solution { public…

对象存储-MinIO-学习-01-安装部署

目录 一、介绍 二、环境信息 三、下载安装包 1、MinIO官网下载地址 2、选择版本 &#xff08;1&#xff09;MinIO Server &#xff08;2&#xff09;MinIO Client &#xff08;3&#xff09;MinIO SDK 四、MinIO SDK安装步骤 1、安装minio库 2、导入minio库报错&…

docker笔记1

docker笔记1 一、为什么要学docker?二、docker是什么三、docker安装 一、为什么要学docker? 在过去&#xff0c;开发人员编写的代码在不同的环境中运行时常常面临一些问题&#xff0c;例如“在我的机器上可以运行&#xff0c;但在你的机器上却不行”的情况。这种问题部分原因…

2024全网最全面及最新且最为详细的网络安全技巧五 之 SSRF 漏洞EXP技巧,典例分析以及 如何修复 (下册)———— 作者:LJS

五.SSRF 漏洞EXP技巧&#xff0c;典例分析以及 如何修复 (下册) 目录 五.SSRF 漏洞EXP技巧&#xff0c;典例分析以及 如何修复 (下册) 5.4gopher 协议初探 0x01 Gopher协议 0x02 协议访问学习 复现环境 centos7 kali 2018 发送http get请求 发送http post请求 5.5 SSRF…

isaac sim 与 WLS2 ros2实现通信

Omniverse以及isaac还是windows下使用顺手一点&#xff0c;但是做跟ros相关的开发时候&#xff0c;基本就得迁移到ubuntu下了&#xff0c;windows下ros安装还是过于复杂&#xff0c;那不想用双系统或者ubuntu或者虚拟机&#xff0c;有啥别的好方法呢&#xff1f;这里想到了wind…

安全求交集PSI

安全求交集定义 求交集的PSI&#xff1a;交集可以被两方看见或其中一方看见&#xff0c;非交集进行保护有两方的PSI半诚实的PSI&#xff1a;攻击者要严格遵守协议&#xff0c;在此基础上得到他人的秘密是做不到的 Two-Party Semi-Honest PSI 挑战一&#xff1a;隐藏非交集元素…

软件测试之冒烟测试

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 1. 核心 冒烟测试就是完成一个新版本的开发后&#xff0c;对该版本最基本的功能进行测试&#x…

使用树莓派进行python开发,控制电机的参考资料

网站连接&#xff1a;https://www.cnblogs.com/kevenduan?page1 1、简洁的过程步骤&#xff0c; 2、有代码示例&#xff0c; 3、有注意事项&#xff0c;

Java核心技术【二十】Java泛型的基本概念和原理详解

Java泛型的基本概念和原理详解 一、泛型的基本概念 Java泛型&#xff08;Generics&#xff09;是Java SE 1.5&#xff08;JDK 5&#xff09;引入的一个新特性&#xff0c;它提供了一种在编译时期进行类型检查的方式&#xff0c;允许程序员在定义类、接口和方法时指定类型参数…

【第25章】MyBatis-Plus之字段类型处理器

文章目录 前言一、JSON 字段类型处理器1. 配置2. XML 配置对应写法3. Wrapper 查询中的 TypeHandler 使用 二、自定义类型处理器1. 创建自定义类型处理器2. 使用自定义类型处理器 三、实战1. 实体类2. 测试类3. 测试结果 总结 前言 在 MyBatis 中&#xff0c;类型处理器&#…

QImage 的图片可以直接显示吗

QImage 对象本身并不直接显示在屏幕上&#xff0c;但你可以很容易地将它转换为 QPixmap&#xff0c;然后使用 QLabel 或其他支持 pixmap 的 Qt 控件来显示它。QPixmap 是为屏幕显示而优化的图像表示&#xff0c;而 QImage 则提供了更多的图像处理能力&#xff0c;如像素访问、转…

Java PKI Programmer‘s Guide

一、PKI程序员指南概述 PKI Programmer’s Guide Overview Java认证路径API由一系列类和接口组成&#xff0c;用于创建、构建和验证认证路径。这些路径也被称作认证链。实现可以通过基于提供者的接口插入。 这个API基于密码服务提供者架构&#xff0c;这在《Java密码架构参考指…

硬件:CPU和GPU

一、CPU与GPU 二、提升CPU利用率&#xff1a;计组学过的 1、超线程一般是给不一样的任务的计算使用&#xff0c;而非在计算密集型工作中 2、Cpu一次可以计算一个线程&#xff0c;而gpu有多少个绿点一次就能计算多少个线程&#xff0c;Gpu比cpu快是因为gpu它的核多&#xff0c;…