Interview AiBox logo

Interview AiBox 实时 AI 助手,让你自信应答每一场面试

download免费下载
入门local_fire_department11 次面试更新于 2025-08-24account_tree思维导图

请写出SQL中的增删改查基本语句

lightbulb

题型摘要

SQL的增删改查(CRUD)是与数据库交互的四个基本操作。**增(INSERT)**用于向表中添加新数据行;**删(DELETE)**用于删除表中的数据行;**改(UPDATE)**用于修改表中已存在的数据;**查(SELECT)**用于从表中检索和查询数据,功能最强大。对于UPDATE和DELETE操作,必须谨慎使用WHERE子句来限定范围,否则会误改或误删全表数据,造成严重后果。

SQL中的增删改查(CRUD)是与数据库交互最核心的四个基本操作。它们分别是INSERT(增加)、SELECT(查询)、UPDATE(修改)和DELETE(删除)。对于测试开发岗位,熟练掌握这些基本语句是进行数据准备、结果验证和数据库状态检查的基础。

为了更好地说明,我们先假设有一个 Users 表,其结构如下:

--- title: Users 表实体关系图 --- erDiagram Users { int id PK "用户ID (主键)" varchar username "用户名" varchar email "电子邮箱" datetime created_at "创建时间" }

一、数据增加 - INSERT 语句

INSERT 语句用于向数据表中插入新的数据行

1. 插入单行数据(指定列) 这是最常用的方式,可以只为部分列插入值。

-- 向 Users 表中插入一条新用户记录,只指定 username 和 email
INSERT INTO Users (username, email, created_at)
VALUES ('zhangsan', 'zhangsan@example.com', NOW());

2. 插入单行数据(为所有列) 如果为表中所有列都提供值,可以省略列名列表,但值的顺序必须与表结构中列的顺序完全一致。

-- 假设表结构为 (id, username, email, created_at)
-- id 是自增主键,可以用 NULL, 0 或 DEFAULT 来让数据库自动生成
INSERT INTO Users
VALUES (DEFAULT, 'lisi', 'lisi@example.com', NOW());

3. 一次性插入多行数据 通过一个 INSERT 语句可以插入多条记录,这在测试数据准备时非常高效。

-- 一次性插入多个用户
INSERT INTO Users (username, email, created_at)
VALUES 
  ('wangwu', 'wangwu@example.com', NOW()),
  ('zhaoliu', 'zhaoliu@example.com', NOW()),
  ('sunqi', 'sunqi@example.com', NOW());

二、数据查询 - SELECT 语句

SELECT 语句用于从数据库中查询和检索数据,是SQL中最复杂、功能最强大的语句。

1. 查询所有数据 使用 * 通配符可以返回表中所有列的数据。

-- 查询 Users 表中的所有用户和所有字段信息
SELECT * FROM Users;

2. 查询指定列 明确指定需要查询的列名,可以获得更精确、更高效的数据。

-- 只查询所有用户的用户名和邮箱
SELECT username, email FROM Users;

3. 带条件的查询 (WHERE) 使用 WHERE 子句可以过滤出满足特定条件的行。

-- 查询用户名为 'zhangsan' 的用户信息
SELECT * FROM Users WHERE username = 'zhangsan';

-- 查询ID大于2的所有用户
SELECT id, username FROM Users WHERE id > 2;

4. 排序查询结果 (ORDER BY) 使用 ORDER BY 子句可以对查询结果进行排序,ASC 表示升序(默认),DESC 表示降序。

-- 按创建时间降序查询所有用户,即最新的用户排在前面
SELECT * FROM Users ORDER BY created_at DESC;

5. 限制返回数量 (LIMIT) 使用 LIMIT 子句可以限制返回的行数,常用于分页。

-- 查询最新的2个用户
SELECT * FROM Users ORDER BY created_at DESC LIMIT 2;

三、数据修改 - UPDATE 语句

UPDATE 语句用于修改数据表中已存在的数据行

⚠️ 警告: UPDATE 操作必须配合 WHERE 子句使用,否则将会更新整张表的所有数据,造成灾难性后果。

-- 将用户名为 'zhangsan' 的用户的邮箱更新为新邮箱
UPDATE Users
SET email = 'new_zhangsan@example.com'
WHERE username = 'zhangsan';

-- 同时更新多个字段
UPDATE Users
SET email = 'contact@example.com', created_at = NOW()
WHERE id = 1;

四、数据删除 - DELETE 语句

DELETE 语句用于从数据表中删除数据行

⚠️ 警告:UPDATE 一样,DELETE 操作必须配合 WHERE 子句使用,否则将会清空整张表。

-- 删除 ID 为 3 的用户
DELETE FROM Users WHERE id = 3;

-- 删除用户名为 'lisi' 的用户
DELETE FROM Users WHERE username = 'lisi';

如果要删除表中的所有行,虽然可以使用不带 WHEREDELETE,但更推荐使用 TRUNCATE TABLE 语句,因为它通常更快,并且会重置自增ID等表属性。

-- 清空 Users 表(更高效,但不可回滚)
TRUNCATE TABLE Users;

总结对比

操作 SQL关键字 主要功能 核心注意事项
INSERT INTO 添加新数据行 值的顺序和数量需与列匹配
DELETE FROM 删除数据行 务必使用WHERE子句,防止清空表
UPDATE ... SET 修改现有数据 务必使用WHERE子句,防止更新全表
SELECT ... FROM 检索数据 功能最丰富,可配合WHERE, ORDER BY

权威参考

account_tree

思维导图

Interview AiBox logo

Interview AiBox — 面试搭档

不只是准备,更是实时陪练

Interview AiBox 在面试过程中提供实时屏幕提示、AI 模拟面试和智能复盘,让你每一次回答都更有信心。

AI 助读

一键发送到常用 AI

SQL的增删改查(CRUD)是与数据库交互的四个基本操作。**增(INSERT)**用于向表中添加新数据行;**删(DELETE)**用于删除表中的数据行;**改(UPDATE)**用于修改表中已存在的数据;**查(SELECT)**用于从表中检索和查询数据,功能最强大。对于UPDATE和DELETE操作,必须谨慎使用WHERE子句来限定范围,否则会误改或误删全表数据,造成严重后果。

智能总结

深度解读

考点定位

思路启发

auto_awesome

相关题目

请做一个自我介绍

自我介绍是面试的开场环节,应控制在2-3分钟内,包含基本信息、教育背景、项目经验、个人特点、求职动机和结束语。关键在于突出与岗位相关的技能和经验,用具体事例支撑能力,展现对公司和岗位的了解。表达时应保持自信、简洁明了,避免背诵简历内容或过度夸张。准备过程包括分析岗位需求、梳理个人经历、找出匹配点、构建框架、撰写初稿、修改润色、模拟练习和最终定稿。

arrow_forward

如何编写有效的测试用例?请分享你的方法和经验。

编写有效的测试用例是软件测试的核心工作。有效测试用例应具备准确性、清晰性、可执行性、可重复性、独立性、完备性和可追踪性。常用测试用例设计方法包括等价类划分法、边界值分析法、决策表法、状态转换法和场景法。测试用例设计流程包括需求分析、确定测试范围、识别测试条件、选择测试方法、设计测试用例、评审优化、执行测试、分析结果和维护用例库。最佳实践包括遵循需求驱动、保持用例独立性、注重可维护性、平衡广度深度、持续优化。测试用例管理工具如TestRail、Zephyr等可提高测试效率。从用户角度思考、关注边界异常、利用历史数据、重视非功能测试和与开发团队合作是重要的经验分享。

arrow_forward

请谈谈你对测试开发工程师这个角色的理解

测试开发工程师是介于传统测试工程师和开发工程师之间的角色,核心定位是"质量赋能者"。他们通过编写代码、工具和框架来提高测试效率和质量,职责包括测试框架开发、自动化测试实现、测试策略制定、质量度量分析等。测试开发工程师需要具备"T型"知识结构,既有编程能力、测试专业知识,又有系统设计能力和DevOps实践。在软件开发生命周期的各个阶段都能发挥重要作用,从需求分析到线上运维。职业发展路径包括技术专家、管理、产品和转型等多个方向。未来,测试开发工程师将面临AI赋能、质量保障前置、全流程监控等趋势,需要不断拓展技术能力,成为连接开发、测试和运维的桥梁。

arrow_forward

如果让你为一个登录功能设计测试用例,你会考虑哪些方面和场景?

登录功能测试用例设计需全面考虑功能、界面、安全、性能、兼容性、异常和用户体验七个方面。功能测试验证基本功能是否正常,包括正向和反向测试;界面测试确保布局样式符合设计;安全测试检查漏洞防护;性能测试评估负载表现;兼容性测试验证多环境适配;异常测试检验异常处理能力;用户体验测试评估易用性。通过这七个方面的全面测试,可确保登录功能的质量和可靠性。

arrow_forward

排查慢SQL的常见原因有哪些?如何优化?

慢SQL是指执行时间超过阈值的SQL查询,会导致用户体验下降、系统资源消耗增加等问题。常见原因包括索引问题(缺少索引、索引失效)、查询语句问题(SELECT *、复杂JOIN)、数据库设计问题(表结构不合理、数据类型不当)、配置问题(参数配置不当、硬件资源不足)以及数据量问题(数据量过大、分布不均)。排查方法包括慢查询日志分析、执行计划分析、性能分析工具和监控告警。优化策略涵盖索引优化(合理创建索引、遵循索引设计原则)、SQL语句优化(避免SELECT *、优化JOIN和分页)、数据库设计优化(表拆分、适当冗余)、配置优化(内存和连接参数调整)以及架构优化(读写分离、缓存、分库分表)。预防慢SQL需要在开发、部署和运维各阶段遵循最佳实践,并借助工具支持。

arrow_forward

阅读状态

阅读时长

5 分钟

阅读进度

17%

章节:6 · 已读:1

当前章节: 一、数据增加 - `INSERT` 语句

最近更新:2025-08-24

本页目录

Interview AiBox logo

Interview AiBox

AI 面试实时助手

面试中屏幕实时显示参考回答,帮你打磨表达。

免费下载download

分享题目

复制链接,或一键分享到常用平台

外部分享