初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作

找往期文章包括但不限于本期文章中不懂的知识点:

个人主页:我要学编程(ಥ_ಥ)-CSDN博客

所属专栏: MYSQL

前面我们学习了创建、删除数据库以及创建、查看、删除数据表的相关操作。 我们知道数据库中所存储的数据其实就是数据表中一条一条的记录。但是我们在创建数据表时,其没有存放任何数据。因此今天我们就来学习如果在数据表中存储数据记录,以及查看、删除等操作。

对数据表的一系列操作,我们称之为CRUD,即增删改查。

C - Create(增加);R - Retrieve(查询);U - Update(更新);D - Delete(删除)

目录

新增(Create)

查询(Retrieve)

修改(Update) 

删除(Delete)


新增(Create)

新增其实就是插入数据。其对应的语法是:

INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);

 参数说明与注意事项:

1、table_name是你要插入数据的表的名称;

2、column1,column2,column3,..是表中的列名,也就是字段(属性);

3、value1,value2,value3,..是要插入的具体数值,与列名的顺序是相对应的;

4、如果要插入的数据是字符型,必须使用单引号 引起数据。

5、如果我们要插入所有列的数据,可以省略列名;否则,就得指定列名插入;

6、插入数据时,也可以同时插入多条数据。

代码演示:

insert into books (name, author, price, sort) 
values ('大话数据结构', '程杰', 59, '计算机');

注意:如果我们数据库的编码集使用的是Latin1 的话,就不能写入中文。要么将配置文件中的数据库服务的编码集改成 utf8mb4;要么在创建数据库时,将编码集设置成 utf8mb4。

插入完成之后,我们可以进行查询操作,来观察插入的数据是否符合我们的要求。

查询(Retrieve)

语法:

SELECT column1, column2, ...
FROM table_name
[WHERE condition]
[ORDER BY column_name [ASC | DESC]]
[LIMIT number];

参数说明与注意事项:

1、column1,column2,..是你想要查询的列的名称,如果使用*表示查询所有列。这里查询的结果也可以是一个表达式;

2、table_name 是你要查询的数据的表的名称;

3、WHEREcondition 是一个可选的子句,用于指定过滤条件,只返回符合条件的行。意思就是说这里是用来筛选数据的条件语句,可写可不写;

4、ORDER BY column_name[ASC」DESC]是一个可选的子句,用于指定结果集的排序顺序,默认是升序(ASC)。这里是对我们查询的结果集进行排序,默认情况下是升序(不写),即ASC,降序是DESC;

5、LIMIT number 是一个可选的子句,用于限制返回的行数。即分页查询;

6、DESC在SQL语句中有两个意思。一个是表示查询表的结构;另一个是表示降序排序 ;

7、分页查询是在查询结果过多时,将查询结果分成多页返回,并允许用户通过翻页来查看完整数据的一种查询方式。如下所示:

8、 也可以为查询的列名起一个简单易懂别名,这样在返回的查询结果中也是别名;

9、在查询的结果中,可能会出现重复的数据行,如果想要去除的话,可以加上一个关键字:DISTINCT。如果DISTINCT关键字后面有多个列名,只有当这些列名对应的数据都相同时,才能被看做是一组相同的数据。

10、WHERE条件可以使用表达式,但不能使用别名。这里我们就得来学习SQL语句中的执行顺序了。如下所示:

那有的小伙伴就会想到:既然在select子句中不能写,那么我在where子句中写不就行了吗?这里就违反了SQL的语法了。语法规定:别名只能在select子句中命名。 

代码演示: 

select * from books; -- 查询books表中所有的数据记录select name from books; -- 指定查询name这一列select chinese + english + math from score; -- 查询chinese+english+math的总成绩-- 查询chinese+english+math的总成绩并为其起一个别名总成绩
-- as 也是可以省略的,后面的字符串如果中间没有空格隔开的话,也是可以不加单引号的
select chinese + english + math as '总分' from score; -- 这里的是一个数据行的不同列相加-- 查询name为大话数据结构的全部信息
select * from books where name = '大话数据结构';select distinct name from books; -- 查询不同名字的书籍select price from books order by price asc; -- 将书籍的价格按照升序的结果排列-- 限制查询的结果一次只显示5条记录
select price from books order by price asc limit 5;
-- 下面的写法也和上面的写法效果是一样的-- 0 表示从第0条记录开始,5 表示一次性显示5条记录(这个可以跳着显示)
select price from books order by price asc limit 0, 5;
-- offset 表示偏移量,也就是从哪条记录开始,5 表示一次性显示5条记录(也可以跳着显示)
select price from books order by price asc limit 5, offset 0;

注意:在排序数据时,当有一列中出现了NULL时,这个NULL视为比任何值都要小。即升序是在最上方,降序是在最下方。 

在进行where的条件查询时,可能还需要用到下面这些比较运算符和逻辑运算符等。

比较运算符

运算符说明
>  >=  <  <=大于,大于等于,小于,小于等于
=等于,NULL不安全,就是说 NULL = NULL的结果是NULL
<=>等于,NULL安全,就是说NULL <=> NULL的结果是TRUE
!=  <>不等于
BETWEEN n0 AND n1

范围匹配,[a0,a1],如果 a0 <= value <= a1,返回 TRUE;否则,返回FALSE

IN (option., ...)如果是集合 option 中的任意一个,返回 TRUE
IS NULL是 NULL
IS NOT NULL不是 NULL
LIKE模糊匹配。%表示可以匹配任意多个(包括0个)任意字符;_表示只能匹配任意一个字符(只能是1个)

 注意:这里和 LIKE 搭配的%和 _ 都是占位符。

运算符

运算符说明
AND多个条件同时都为TRUE时,结果才是TRUE;否则为FALSE
OR任意一个条件为TRUE时,结果都为TRUE;否则,就是FALSE
NOT条件为TRUE时,结果为FALSE;反之,则为TRUE

 注意:AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分。其实我们建议只要是在使用时,遇到了有歧义的部分都是使用()给表明优先级的。

代码练习:

-- 查询价格在60~100之间的书籍相关信息(这里也可以用 >= 和 <= 来实现)
select * from books where price between 60 and 100;-- 查询name中含有 数据结构 的书籍
select * from books where name like '%数据结构%';
-- 以下书籍皆可被查询到:大话数据结构、数据结构C语言版

修改(Update) 

语法: 

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

参数说明以及注意事项:

1、 table_name 是要更新数据的表的名称;

2、columnl,column2,..是要更新的列的名称;

3、valuel,value2,..是新的值,用于替换l日的值;

4、WHERE condition 是一个可选的子句,用于指定更新的行。如果省略WHERE子句,将更新表中的所有行,这是一个非常危险的操作;

5、WHERE子句后面也可以跟order by子句和limit 语句

代码练习:

-- 将书名为大话数据结构的书籍的相关信息更改为下面这些信息
update books set name = '阿里巴巴《Java开发手册-嵩山版》',
author = '众多Java开发者们', price = 0, sort = '计算机'
where name = '大话数据结构'; -- where子句一定不能少,否则就是全部修改了-- 将书名为大话书籍结构的书籍价格提高为原来的两倍
update books set price = price * 2 where name = '大话数据结构';-- 将书籍价格最贵的前三种,全部减去10元
update books set price = price - 10 order by price desc limit 3;

注意:SQL语法中没有复合运算符。如:+=、-=、*=.....这些操作都是错误的。 

我们知道了当没有写where子句时,便会全部修改,从这里也侧面反映了一个问题:当匹配到符合要求的数据时,会一次性全部修改,而不是只修改一条数据。

删除(Delete)

语法:

-- 注意:这里删除的是一条一条的记录,即数据行
DELETE FROM table_name WHERE condition;

参数以及注意事项:

1、table_name是你要删除数据的表的名称;

2、WHERE condition 是一个可选的子句,用于指定删除的行。如果省略 WHERE 子句,将删除表中的所有行,即将表中所有数据全部删除了,这同样是一个非常危险的操作;

3、同样在WHERE子句后面可以跟 order by子句和limit 语句。

代码练习:

-- 删除书籍名为大话数据结构或者是数据结构C语言版的全部信息(这里一定要加where子句)
delete from books where name = '大话数据结构' or name = '数据结构C语言版';-- 将价格最低的三本书全部删除
delete from books order by price asc limit 3;

上面就是关于数据表的增删查改操作。 

好啦!本期 初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作 的学习就到处结束啦!我们下一期再一起学习吧!

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

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

相关文章

前端技术(六)—— AJAX详解

一、原生 AJAX 1. AJAX 简介 AJAX 全称为 Asynchronous JavaScript And XML&#xff0c;就是异步的 JS 和 XML。 通过 AJAX 可以在浏览器中向服务器发送异步请求&#xff0c;最大的优势&#xff1a;无刷新获取数据。 AJAX 不是新的编程语言&#xff0c;而是一种将现有的标准组…

MySQL 数据库管理与操作指南

文章目录 MySQL 数据库管理与操作指南1. 忘记 MySQL 密码的处理方法2. MySQL 数据库备份与恢复2.1 数据库备份2.2 数据库恢复 3. MySQL 用户与权限管理3.1 创建用户与授权3.2 查看所有用户3.3 删除用户 4. 关闭 GTID 复制模式5. 查看数据表的存储引擎5.1 查看 MySQL 支持的存储…

大语言模型(LLM)如何更好地继续预训练(Continue PreTraining)

预训练&#xff08;Pretraining&#xff09;是一个非常消耗资源的工作&#xff0c;尤其在 LLM 时代。随着LLama2的开源&#xff0c;越来越多人都开始尝试在这个强大的英文基座模型上进行中文增强。但&#xff0c;我们如何才能保证模型在既学到「中文知识」的情况下&#xff0c;…

【spring】 Jackson :@JsonIgnore 注解

@JsonIgnore 是 Jackson 库中的一个注解,用于在序列化和反序列化过程中忽略某个字段。也就是说,当对象被转换为 JSON 或从 JSON 转换为对象时,带有 @JsonIgnore 注解的字段将不会被包含在内在这个示例中,ignoredField 字段将不会出现在生成的 JSON 字符串中。 import com.…

灰光模块,彩光模块-介绍

1. 引用 知识分享系列一&#xff1a;5G基础知识-CSDN博客 5G前传的最新进展-CSDN博客 灰光和彩光_通信行业5G招标系列点评之二&#xff1a;一文读懂5G前传-光纤、灰光、彩光、CWDM、LWDM、MWDM...-CSDN博客 ADOP带你了解&#xff1a;CWDM、DWDM、MWDM、LWDM&#xff1a;快速…

网络编程day03(网络体系结构、调试命令、TCP/IP对比)

目录 1》网络的体系结构 1> OSI模型 2> TCP/IP模型 3> 常见网络协议 4> DNS域名解析协议 2》 网络调试命令 1> ping&#xff1a;测试网络连通性&#xff08;ICMP&#xff09; 2> netstat 3》Dos &#xff08;拒绝式服务&#xff09;攻击&#xff1f;…

【大模型-RAG】RAG最佳实践论文及项目解读

文章目录 论文概述RAG工作流程核心代码解读软件架构查询引擎构建数据加载与索引创建微调嵌入模型 项目应用结论 在人工智能领域&#xff0c;大型语言模型&#xff08;LLMs&#xff09;因其强大的文本生成能力而备受关注。然而&#xff0c;这些模型在生成信息时可能会产生过时的…

HTML和HTML5有什么区别

HTML&#xff08;超文本标记语言&#xff09;是构建网页的基础&#xff0c;而HTML5是HTML的最新版本。虽然HTML和HTML5在许多方面相似&#xff0c;但HTML5引入了许多新的特性和改进&#xff0c;使得网页开发更加高效和功能丰富。 一、HTML概述 HTML&#xff0c;即超文本标记语…

分布式锁的实现:ZooKeeper 的解决方案

在分布式系统中&#xff0c;不同的服务或进程需要访问共享资源时&#xff0c;常常需要一种机制来确保在同一时刻只有一个服务或进程能够访问资源。这种机制被称为分布式锁。ZooKeeper&#xff0c;一个为分布式应用提供一致性服务的开源协调服务&#xff0c;提供了一种实现分布式…

Django 测试指南

#Django 测试指南 对绝大部分人来说&#xff0c;测试Django应用感觉很神秘&#xff0c;他们只是听说代码必须要测试&#xff0c;但是经常找不到线索如何入手。当他们看了Django的测试文档&#xff0c;他们找到深入的哪些功能是可用的&#xff0c;但是如果实现没有任何指导。 …

代码随想录:96. 不同的二叉搜索树

96. 不同的二叉搜索树 class Solution { public:int numTrees(int n) {int dp[30]{0};//由i个结点组成的二叉搜索树有多少种dp[0]1; for(int i1;i<n;i)for(int j0;j<i;j)//j表示根节点左子树有j个结点dp[i]dp[j]*dp[i-j-1];//对根节点左右子树结点数量遍历//数量有左子树…

什么是数据结构三要素?

目录 1.逻辑结构 2.数据的存储结构 3.数据的运算 1.逻辑结构 逻辑结构是指数据元素之间的逻辑关系&#xff0c;即从逻辑关系上描述数据。 它与数据的存储无关&#xff0c;是独立于计算机的。数据的逻辑结构非为线性结构和非线性结构&#xff0c;线性表是典型的线性结构&am…

ELK学习笔记——如何给Kibana新增用户和角色

Kibana新增用户和角色 首先用超管账号登录上Kibana&#xff0c;按照下面步骤操作 1、创建角色 按图操作 2、创建用户 按图操作 3、给用户分配角色 至此&#xff0c;角色和用户绑定成功&#xff1b; 最后&#xff0c;可以退出管理员账号&#xff0c;登录这个新…

【MATLAB】FIR滤波器的MATLAB实现

FIR滤波器的MATLAB实现 FIR滤波器的设计fir1函数fir2函数 与IIR滤波器相比&#xff0c;FIR滤波器既有其优势也有其局限性。FIR滤波器的主要优点包括&#xff1a; 精确的线性相位响应&#xff1b;永远保持稳定性&#xff1b;设计方法通常是线性的&#xff1b;在硬件实现中具有更…

Django学习实战篇二(适合略有基础的新手小白学习)(从0开发项目)

前言&#xff1a; 从这一章开始&#xff0c;我们来创建项目typeidea&#xff0c;我把它放到了GitHub上。强烈建议你也到GitHub上注册一个账号&#xff08;如果没有的话&#xff09;&#xff0c;然后创建这样的项目。当然&#xff0c;你也可以起一个属于自己的名称。这个项目就是…

Live800:以客户为中心,重塑服务标准

在快速迭代的商业环境中&#xff0c;企业若想持续繁荣&#xff0c;就必须不断审视并优化自身的服务模式。传统上&#xff0c;服务往往被视为产品交易的附加品&#xff0c;但今日之市场&#xff0c;服务已悄然成为企业核心竞争力的关键要素。因此&#xff0c;“以客户为中心&…

Excel数据导入MySQL数据库的完整指南

在日常的数据处理工作中&#xff0c;经常需要将Excel中的数据导入到MySQL数据库中&#xff0c;以便进行进一步的数据分析和管理。本文将详细介绍如何将Excel数据导入MySQL数据库的完整步骤&#xff0c;包括数据准备、数据库连接、数据导入以及验证等关键步骤。 一、准备工作 …

PostgreSQL 17即将发布,新功能Top 3

按照计划&#xff0c;PostgreSQL 17 即将在 2024 年 9 月 26 日发布&#xff0c;目前已经发布了第一个 RC 版本&#xff0c;新版本的功能增强可以参考 Release Notes。 本文给大家分享其中 3 个重大的新增功能。 MERGE 语句增强 MERGE 语句是 PostgreSQL 15 增加的一个新功能…

5、Django Admin后台移除“删除所选”操作

默认情况下&#xff0c;Django Admin后台的listview模型列表页&#xff0c;会有一个Delete Selected删除所选操作。假设你需要再从Hero管理模型中移除该删除操作。 ModelAdmin.get_actions方法可以返回所有的操作方法。通过覆盖此方法&#xff0c;移除其中delete_selected方法…

pytorch torch.einsum函数介绍

torch.einsum 是 PyTorch 中一个强大且灵活的张量运算函数,基于爱因斯坦求和约定进行操作。它允许用户通过简单的字符串表达式来定义复杂的张量运算,代替显式的循环或多个矩阵乘法操作。 函数签名 torch.einsum(equation, *operands) → Tensor参数 equation: 一个字符串,…