当前位置: 首页 > news >正文

MySQL 从入门到精通(六):视图全面详解 —— 虚拟表的灵活运用

在数据库开发中,我们经常需要重复执行复杂的多表查询,或是需要限制用户只能访问特定数据。这时候,MySQL 的 视图(View)就能大显身手。作为一种 “虚拟表”,视图不存储实际数据,却能基于 SQL 查询动态生成结果,帮我们简化操作、控制权限、提升灵活性。本文将从基础到进阶,全面解析视图的核心用法与实战技巧。


一、视图的本质与核心作用

1.1 什么是视图?

视图是 MySQL 中一种逻辑表,它本身不存储数据,而是通过 CREATE VIEW 语句定义的一条 SQL 查询,将基表(真实表)的数据动态映射出来。简单来说,视图就像是 “查询结果的快照”,用户查询视图时,MySQL 会自动执行定义视图的 SQL 语句,返回实时数据。

例如,若经常需要查询学生及其成绩(涉及 student 和 sc 表连接),可以创建一个视图 v_score 封装这个查询:

CREATE VIEW v_score AS 
SELECT s.sno, s.sname, s.ssex, sc.score 
FROM student s 
JOIN sc ON s.sno = sc.sno;

后续查询时只需 SELECT * FROM v_score,无需重复编写连接逻辑。

1.2 视图的核心价值

  • 简化复杂查询:封装高频使用的多表连接、过滤或计算逻辑,后续调用只需操作视图。
  • 数据安全控制:通过视图限制用户只能访问特定字段(如隐藏手机号、薪资等敏感列)。
  • 逻辑独立性:基表结构变更时(如新增字段),只需调整视图定义,不影响上层业务。
  • 降低维护成本:复杂查询只需在视图中编写一次,避免重复代码。

二、视图的完整操作指南

2.1 创建视图:基础与进阶

基础语法
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION];
  • OR REPLACE:若视图已存在则覆盖(避免删除重建)。
  • ALGORITHM:可选,控制视图执行方式(MERGE 直接合并查询,TEMPTABLE 生成临时表,默认 UNDEFINED 由 MySQL 自动选择)。
  • column_list:自定义视图列名(可选,默认使用查询结果的列名)。
  • WITH CHECK OPTION:强制更新视图时满足 WHERE 条件(后文详细说明)。
示例 1:单表视图(基础查询)
-- 创建学生年龄视图(计算年龄)
CREATE VIEW v_student_age AS 
SELECT sno, sname, YEAR(NOW()) - YEAR(birth) AS age 
FROM student;

查询视图:SELECT * FROM v_student_age; 会直接返回计算后的年龄。

示例 2:多表连接视图(简化业务逻辑)
-- 创建学生成绩视图(关联 student 和 sc 表)
CREATE VIEW v_student_score AS 
SELECT s.sno, s.sname, s.ssex, sc.score 
FROM student s 
INNER JOIN sc ON s.sno = sc.sno;

后续查询学生成绩时,只需 SELECT * FROM v_student_score;,无需重复写连接逻辑。

示例 3:带字段别名的视图(明确业务含义)
-- 创建性别平均分视图(列别名更清晰)
CREATE OR REPLACE VIEW v_sex_avg(性别, 平均分) AS 
SELECT ssex, ROUND(AVG(score), 2) 
FROM student 
JOIN sc ON student.sno = sc.sno 
GROUP BY ssex;

查询结果列名直接显示为 “性别” 和 “平均分”,更易理解。

2.2 更新视图:修改数据会同步到基表吗?

视图的更新(INSERT/UPDATE/DELETE)本质是对基表数据的修改,但并非所有视图都可更新。以下情况视图不可更新:

  • 包含聚合函数(如 AVGSUM)、DISTINCTGROUP BYHAVING 或 UNION 的查询。
  • 基于不可更新视图的子查询。
  • 视图列来自表达式(如 YEAR(NOW()) - YEAR(birth) 生成的 age 列)。
可更新视图的条件

若视图基于单表且未使用上述复杂操作,通常可更新。例如:

-- 创建可更新视图(仅筛选年龄>20的学生)
CREATE VIEW v_adult_student AS 
SELECT sno, sname, sage 
FROM student 
WHERE sage > 20 
WITH CHECK OPTION;  -- 强制更新时满足 WHERE 条件
  • 更新视图:UPDATE v_adult_student SET sage = 22 WHERE sno = 's001'; 会同步修改基表 student
  • 若尝试将年龄改为 18(违反 WHERE sage > 20),会报错:CHECK OPTION failed

2.3 修改视图:调整结构或逻辑

有两种方式修改视图定义:

方式 1:CREATE OR REPLACE VIEW(推荐)

直接覆盖原视图定义,适合快速调整:

-- 原视图仅包含姓名和年龄,新增班级字段
CREATE OR REPLACE VIEW v_student_age AS 
SELECT sno, sname, sclass, YEAR(NOW()) - YEAR(birth) AS age 
FROM student;
方式 2:ALTER VIEW(更严谨)

显式修改视图结构,适合团队协作时明确操作:

-- 修改视图,仅保留女生记录
ALTER VIEW v_student_age AS 
SELECT sno, sname, YEAR(NOW()) - YEAR(birth) AS age 
FROM student 
WHERE ssex = '女';

2.4 删除视图:清理无用资源

DROP VIEW [IF EXISTS] view_name;
  • IF EXISTS:避免视图不存在时抛错。
  • 示例:DROP VIEW IF EXISTS v_student_age;

三、视图的高阶技巧与避坑指南

3.1 控制数据访问权限:隐藏敏感字段

通过视图只暴露部分字段,可保护敏感数据。例如,员工表包含 salary 敏感列,但普通用户只需查看姓名和部门:

CREATE VIEW v_employee_public AS 
SELECT name, department 
FROM employee;

普通用户查询 v_employee_public 时,无法获取 salary 信息。

3.2 WITH CHECK OPTION:强制数据一致性

若视图定义了 WHERE 条件(如筛选年龄 > 20),使用 WITH CHECK OPTION 可确保更新操作不会插入 / 修改后的数据违反该条件。例如:

CREATE VIEW v_high_salary AS 
SELECT id, name, salary 
FROM employee 
WHERE salary > 10000 
WITH CHECK OPTION;

尝试插入 salary=8000 的记录会报错,避免脏数据。

3.3 视图嵌套与性能优化

视图可嵌套使用(基于其他视图创建新视图),但需注意:

  • 嵌套视图可能导致查询性能下降(每层视图都会生成临时结果)。
  • 优先使用 MERGE 算法(ALGORITHM=MERGE),避免 TEMPTABLE 生成临时表的额外开销。

3.4 视图 vs 临时表:如何选择?

  • 视图:适合高频重复查询(逻辑固定,无需每次重写 SQL),数据实时更新(依赖基表)。
  • 临时表:适合一次性复杂计算(结果需持久化或多次使用),数据独立于基表。

四、总结:视图的最佳实践场景

视图是 MySQL 中非常灵活的工具,以下场景强烈推荐使用:

  • 高频复杂查询:如多表连接、过滤条件固定的查询,用视图封装。
  • 权限控制:限制用户只能访问特定字段或行(如仅显示本部门数据)。
  • 接口抽象:基表结构变化时,通过修改视图定义保持上层业务逻辑不变。

注意事项

  • 避免在视图中使用 ORDER BY(外层查询可能覆盖排序)。
  • 定期清理不再使用的视图(SHOW TABLES 可查看视图列表)。
  • 对可更新视图,确保业务逻辑与基表操作一致(如级联删除需在基表设计触发器)。

通过本文的学习,你已掌握视图从创建到高级应用的全流程。下一篇我们将深入讲解 MySQL 存储过程与函数,解锁更多数据库自动化能力!

相关文章:

MySQL 从入门到精通(六):视图全面详解 —— 虚拟表的灵活运用

在数据库开发中,我们经常需要重复执行复杂的多表查询,或是需要限制用户只能访问特定数据。这时候,MySQL 的 视图(View)就能大显身手。作为一种 “虚拟表”,视图不存储实际数据,却能基于 SQL 查询…...

Linux 下 Java 部署环境搭建与项目部署详细步骤

目录 1. 软件环境准备 1.1 更新软件包库 1.2 安装 OpenJDK 1.3 安装 MySQL 数据库 2. 部署 Web 项目到 Linux 2.1 数据准备和配置 2.2 Maven 打包项目 2.3 上传 Jar 包至云服务器 2.4 启动应用程序 2.5 配置防火墙与端口开放 2.6 访问与验证项目 2.7 进程管理与问题…...

养生:为健康生活添彩

养生是对生活的热爱,是为健康生活注入活力的良方。从饮食、运动到生活习惯,每一个方面都能让我们离健康更近一步。以下是一些实用的养生之道,助你开启健康生活的新旅程。 饮食养生:营养均衡,健康基石 合理的饮食是养…...

Hypermesh四面体网格划分(二)

我们找到“3D-tetramesh”的命令,然后选择“tetra mesh”,以下就是这种四面体网格生成方式的面板。见图1所示。 图1 tetra mesh面板 下面以一个法兰盘的四面体网格划分作为案例,具体介绍基于表面网格的四面体网格生成方式。 首先导入几何模型…...

PySide6 GUI 学习笔记——常用类及控件使用方法(常用类边距QMargins)

文章目录 类概述方法总览使用注意事项简单示例 类概述 QMargins 类用于描述矩形四周边框尺寸,包含左(left)、上(top)、右(right)、下(bottom)四个整型边距值。当所有边距均为0时,isNull() 返回 True。该类支持流式操作和比较运算。 版本信息&#xff1…...

python笔记和练习----少儿编程课程【阶段二(二)】

第13课 列表元素的查找和删除 知识点 1、删除第一个出现的指定元素 列表.remove(元素) 2.删除末尾元素 列表.pop() 3、清空列表的所有数据 列表.clear() 4、删除指定位置的元素 del 列表[索引] del 关键字本质上是用来 将一个变量从内存中删除…...

Excel里面怎样批量去掉字串包含的标点符号

在Excel中批量去除字符串中的标点符号,可以通过以下几种方法实现: 方法1:使用SUBSTITUTE函数嵌套 适用于已知的特定标点符号(需手动列出): SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1, ",&quo…...

Linux 信号终篇(总结)

前文:本文是对信号从产生到被处理的过程中的概念和原理的总结,如果想了解具体实现,请查看前两篇博客:Linux 信号-CSDN博客、Linux 信号(下篇)-CSDN博客 一、信号的产生 1.1 信号产生的五种条件 ①键盘组…...

Springboot之会话技术

会话:用户打开浏览器,访问web服务器的资源,会话建立,直到有一方断开连接,会话结束。在一次会话中可以包含多次请求和响应。 会话跟踪:一种维护浏览器状态的方法,服务器需要识别多次请求是否来自于同一浏览器&#xff…...

数字信号处理|| 离散系统的冲激响应和阶跃响应

一、实验目的 (1)加深对离散线性移不变(LSI)系统基本理论的理解,明确差分方程与系统函数之间的关系。 (2)初步了解用MATLAB语言进行离散时间系统研究的基本方法。 (3)掌…...

JVM 数据区域

JVM 数据区域 1 程序计数器 程序计数器(Program Counter Register) ,也有称作为PC寄存器。在汇编语言中,程序计数器是指CPU中的寄存器,它保存的是程序当前执行的指令的地址,当CPU需要执行指令时&#xff0…...

MRNet 数据集分享

MRNet 数据集分享 包括了2001年1月1日至2012年12月31日期间在斯坦福大学医学中心进行的1370次膝关节MRI检查(平均年龄38.0岁;569例(41.5%)女性患者)。该数据集包含 1,104 (80.6%) 次异常检查,其中319 (23.…...

MCP项目实例 - client sever交互

1. 项目概述 项目目标 构建一个本地智能舆论分析系统。 利用自然语言处理和多工具协作,实现用户查询意图的自动理解。 进行新闻检索、情绪分析、结构化输出和邮件推送。 系统流程 用户查询:用户输入查询请求。 提取关键词:从用户查询中…...

uniapp|实现商品分类与列表数据联动,左侧菜单右侧商品列表(瀑布流、高度自动计算、多端兼容)

基于uniapp实现商品分类与商品列表数据联动,提供完整代码与常见问题解决方案,通过实战案例演示,快速构建商品列表交互,开箱即用。 目录 前言应用场景介绍页面布局与样式整体结构分析左侧菜单样式右侧商品列表样式核心功能实现数据绑定与渲染点击事件交互性能优化图片懒加载…...

1.2.2.1.4 数据安全发展技术发展历程:高级公钥加密方案——同态加密

引言 在密码学领域,有一种技术被图灵奖得主、著名密码学家Oded Goldreich誉为"密码学圣杯",那就是全同态加密(Fully Homomorphic Encryption)。今天我们就来聊聊这个神秘而强大的加密方案是如何从1978年的概念提出&…...

dify插件接入fastmcp示例

文章目录 1. 使用python完成mcp服务1.1 准备环境(python安装fastmcp)1.2 mcp服务端示例代码1.3 启动mcp服务端 2. dify接入2.1 安装MCP SSE和 Agent 策略(支持 MCP 工具) 插件2.2 dify agent插件配置mcp:2.3 mcp服务配置&#xff…...

从文本到语义:BERT、Faiss 与 Elasticsearch 的协同实践

从文本到语义:BERT、Faiss 与 Elasticsearch 的协同实践 在自然语言处理(NLP)的技术栈中,BERT、Faiss 和 Elasticsearch 是三个具有代表性的工具,它们各自发挥着独特的作用。BERT 负责文本的语义理解,Fais…...

安装或更新 CUDA Toolkit - Ubuntu - RuntimeError

1、问题 执行 pip install flash-attn --no-build-isolation 时,出错: RuntimeError: FlashAttention is only supported on CUDA 11.7 and above. Note: make sure nvcc has a torch.__version__ 2.4.0cu12 执行 nvcc --version 或 nvcc -V&…...

二、Hive安装部署详细过程

Apache Hive 是一个构建在 Hadoop 之上的数据仓库基础设施。它提供了类似 SQL 的查询语言 (称为 HiveQL 或 HQL),让熟悉 SQL 的开发人员和分析师能够轻松地查询和分析存储在 HDFS 或其他兼容存储系统中的大规模数据集。把结构化或半结构化的数据映射成表&#xff0c…...

常见的降维算法

作业: 自由作业:探索下什么时候用到降维?降维的主要应用?或者让ai给你出题,群里的同学互相学习下。可以考虑对比下在某些特定数据集上t-sne的可视化和pca可视化的区别。 一、什么时候用到降维? 降维通常…...

Spring Boot 中如何启用 MongoDB 事务

在 Spring Boot 中启用和使用 MongoDB 事务主要依赖于以下几个方面: MongoDB 服务器和部署模式: MongoDB 版本 4.0 或更高版本才支持副本集 (Replica Set) 上的多文档 ACID 事务。MongoDB 版本 4.2 或更高版本才支持分片集群 (Sharded Cluster) 上的多文…...

2025年5月15日前 免费考试了! Oracle AI 矢量搜索专业​​认证

2025年5月5日前 免费考试了! Oracle AI 矢量搜索专业​​认证 立刻预约吧 文章目录 2025年5月5日前 免费考试了! Oracle AI 矢量搜索专业​​认证立刻预约吧🔍 探索 AI 向量搜索的强大功能!🎯 学习路径目标&#x1f6e…...

初等数论--莫比乌斯反演

1. 定义 假设 f ( n ) g ( n ) f(n)\ g(n) f(n) g(n)是定义在正整数上的两个函数 ,且 f ( n ) ∑ d ∣ n g ( d ) ∑ d ∣ n g ( n d ) f(n)\sum_{d|n}g(d)\sum_{d|n}g(\frac{n}{d}) f(n)d∣n∑​g(d)d∣n∑​g(dn​) 那么 g ( n ) ∑ d ∣ n μ ( d ) f ( n d…...

访问者模式(Visitor Pattern)详解

文章目录 1. 访问者模式概述1.1 定义1.2 基本思想2. 访问者模式的结构3. 访问者模式的UML类图4. 访问者模式的工作原理5. Java实现示例5.1 基本实现示例5.2 访问者模式处理复杂对象层次结构5.3 访问者模式在文件系统中的应用6. 访问者模式的优缺点6.1 优点6.2 缺点7. 访问者模式…...

C++ 关联式容器:map,multimap,set,multiset

目录 引言 一、关联式容器概述 1.1 与序列式容器的区别 1.2 底层结构 二、set容器详解set介绍 2.1 set的特性 2.2 set的模板参数 2.3 set的常用接口 2.4 set使用示例 三、map容器详解map介绍 3.1 map的特性 3.2 map的模板参数 3.3 map的常用接口 3.4 map使用示例 …...

Discriminative and domain invariant subspace alignment for visual tasks

用于视觉任务的判别性和域不变子空间对齐 作者:Samaneh Rezaei,Jafar Tahmoresnezhad 文章于2018年12月4日收到,2019年5月24日被接受,2019年6月3日在线发表于Iran Journal of Computer Science期刊,DOI: 10.1007/s42…...

comfyui 如何优雅的从Hugging Face 下载模型,文件夹

如下图所示 使用git 下载整个仓库然后把需要的放到对应的位置...

【C++】 —— 笔试刷题day_27

一、kotori和气球 题目解析 这道题,有n中气球,每一种气球有无数多个;现在我们需要将这些气球摆成一排,但是,如果相邻的气球是相同的就会发生爆炸(也就是说,相同的气球相邻的摆法是不合法的&…...

2025年“深圳杯”数学建模挑战赛C题国奖大佬万字思路助攻

完整版1.5万字论文思路和Python代码下载:https://www.jdmm.cc/file/2712073/ 引言 本题目旨在分析分布式能源 (Distributed Generation, DG) 接入配电网系统后带来的风险。核心风险评估公式为: R P_{loss} \times C_{loss} P_{over} \times C_{over}…...

大模型微调指南之 LLaMA-Factory 篇:一键启动LLaMA系列模型高效微调

文章目录 一、简介二、如何安装2.1 安装2.2 校验 三、开始使用3.1 可视化界面3.2 使用命令行3.2.1 模型微调训练3.2.2 模型合并3.2.3 模型推理3.2.4 模型评估 四、高级功能4.1 分布训练4.2 DeepSpeed4.2.1 单机多卡4.2.2 多机多卡 五、日志分析 一、简介 LLaMA-Factory 是一个…...

游戏引擎学习第268天:合并调试链表与分组

回顾并为今天的内容设定基调 我们正在直播中开发完整的游戏,目前调试系统的开发已接近尾声。这个调试系统的构建过程经历了较长的时间,中间还暂停过一段时间去做硬件渲染路径的开发,并在已有的软件渲染路径基础上进行了扩展。后来我们又回到…...

【Linux系统编程】进程属性--标识符

1.PID 1.1什么是PID? 区分进程的唯一性 1.2如何查看进程? ps ajx | head -1 ; ps ajx | grep myproc 或者ps ajx | head -1 && ps ajx | grep myproc | grep -v grep(过滤掉grep本身这个进程) 1.3进程有哪两种&#…...

React文档-State数据扁平化

1、选择 State 结构 思考一下: 如果渲染列表, 并更新列表数据在下面展示~ state 过去常常是这样复制的: items [{ id: 0, title: pretzels}, ...]selectedItem {id: 0, title: pretzels} 改了之后是这样的:items [{ id: 0, …...

kotlin flow防抖

一 防抖设计 ✅ 1. 点击事件的防抖:用于防止频繁触发逻辑 🎯 适用场景: 用户连续快速点击按钮,可能会导致多次发送网络请求、CAN 指令或反复切换状态等副作用。所以我们通常在点击函数中处理防抖,例如: …...

基础语法(二)

Mysql基础语法(二) Mysql基础语法(二)主要介绍Mysql中稍微进阶一点的内容,会稍微有一些难度(博主个人认为)。学习完基础语法(一)和基础语法(二)之…...

FreeTex v0.2.0:功能升级/支持Mac

概述 FreeTex在发布之后,迎来很多反馈,本次根据主流的反馈建议,又进行一轮小升级,正式发布v0.2.0版本,主要升级点如下: 新增识别结果预览显示 Latex识别结果支持格式化输出 软件体积更小,并移…...

MacOS 用brew 安装、配置、启动Redis

MacOS 用brew 安装、配置、启动Redis 一、安装 brew install redis 二、启动 brew services start redis 三、用命令行检测 set name tom get name...

大型旋转机械信号分解算法模块

大型旋转机械信号分解算法模块,作为信号处理算法工具箱的主要功能模块,可应用于各类关键机械部件(轴承、齿轮、转子、联轴器等)的信号分析、故障探测、趋势劣化评估等,采用全Python语言,以B/S模式&#xff…...

Java 中的数据类型误导点!!!

在 Java 中,数据类型分为两大类:基本类型(Primitive Types) 和 引用类型(Reference Types)。它们的存储方式和行为完全不同。 1. 基本类型 Java 有 8 种基本数据类型,它们直接存储值&#xff…...

Linux--JsonCpp

1.JsonCpp 简介 JsonCpp 是一个用于 C 的 JSON 解析和生成库,支持 JSON 数据的读写、解析和序列化。它提供了简单的 API 来操作 JSON 对象、数组、字符串、数字等类型,是 C 开发中处理 JSON 数据的常用工具。 核心功能与类 JsonCpp 主要包含以下核心类…...

cv_connection (像halcon一样对区域进行打散)

主题: 分享一个自己用opencv写的小方法, 可以像halcon的connection算子一样, 对cv2.threshold得到的region进行打散, 并返回一个打散后的不相连的region的列表。 代码如下 def cv_connection(region):# he的拓扑信息为 后一…...

ConcurrentHashMap和锁

文章目录 JDK1.7的分段锁JDK1.8的volatileCAS synchronized可重入锁公平锁和非公平锁悲观锁和乐观锁 JDK1.7的分段锁 数据结构:数组(大数组 Segment 和小数组 HashEntry)链表 #mermaid-svg-dfSgz5E7tBmTbx14 {font-family:"trebuchet …...

黑马k8s(二)

集群环境搭建 1.环境规划 2.环境搭建-主机安装 主节点: 软件选择选择 基础设施服务器,这样安装系统完毕之后,会有很多软件我们可以直接使用了 系统点开,点一下完成 ip地址的设置:要跟虚拟网络编辑器,Net…...

LeetCode热题100--240.搜索二维矩阵--中等

1. 题目 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性: 每行的元素从左到右升序排列。 每列的元素从上到下升序排列。 示例 1: 输入:matrix [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[1…...

python校园新闻发布管理系统

目录 技术栈介绍具体实现截图系统设计研究方法:设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理,难度适中&#xf…...

Spring MVC 视图解析器 (ViewResolver) 如何配置? Spring Boot 是如何自动配置常见视图解析器的?

我们来详细分析一下视图解析器 (ViewResolver) 的配置以及 Spring Boot 是如何自动配置它们的。 视图解析器 (ViewResolver) 是什么? 在 Spring MVC 中,当控制器 (Controller) 方法处理完请求并返回一个逻辑视图名 (String) 时,DispatcherS…...

LeetCode 2918.数组的最小相等和:if-else

【LetMeFly】2918.数组的最小相等和:if-else 力扣题目链接:https://leetcode.cn/problems/minimum-equal-sum-of-two-arrays-after-replacing-zeros/ 给你两个由正整数和 0 组成的数组 nums1 和 nums2 。 你必须将两个数组中的 所有 0 替换为 严格 正…...

C++修炼:stack和queue

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《题海拾贝》、《C修炼之路》 欢迎点赞&#xff0c;关注&am…...

欧拉计划 Project Euler 69(欧拉总计函数与最大值)题解

欧拉计划 Project Euler 69 题解 题干欧拉总计函数与最大值 思路code 题干 欧拉总计函数与最大值 小于 n n n且与 n n n互质的正整数的数量记为欧拉总计函数 φ ( n ) \varphi(n) φ(n)&#xff0c;例如&#xff0c; 1 、 2 、 4 、 5 、 7 1、2、4、5、7 1、2、4、5、7和 8 …...

TCP Socket编程

最基本的Socket编程 想客户端和服务器能在网络中通信&#xff0c;就得使用 Socket 编程&#xff0c;它可以进行跨主机间通信。在创建Socket时可以选择传输层使用TCP还是UDP。相对于TCP来说&#xff0c;UDP更为简单&#xff0c;下面以TCP为例。 TCP服务端要先建立起来&#xf…...