【MySQL】表的增删改查(强化)

news2024/11/26 5:27:03

作者主页:paper jie_博客

本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。

本文录入于《MySQL》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将MySQL基础知识一网打尽,希望可以帮到读者们哦。

其他专栏:《算法详解》《C语言》《javaSE》《数据结构》等

内容分享:本期将会分享MySQL表的增删改查的一些奇淫巧技

目录

数据库的约束

约束类型

null约束

unique: 唯一约束 

default: 默认值约束

primary key: 主键约束

foreign key: 外键约束

check约束(MySQL中不使用它)

表的设计

三大范式

一对一

一对多

多对多

新增

查询

聚合查询

聚合函数

group by 子句

having

联合查询

初始化数据

内连接

外连接

自连接

子查询

合并查询


数据库的约束

约束类型

not null: 表示某列不可以存放null

unique: 保证某列的每行必须是唯一值

default: 规定没有给列赋值时给的默认值

primary key: 主键, 保证某列有唯一的标记,且不能为null

foreign key: 外键, 保证一个表的数据匹配另一个表的值的参照完整性,与匹配表对应

check: 保证列中的值符合指定的条件,但MySQL数据库堆check子句进行分析的时候会忽略它

null约束

 创建表的时候,指定列不能为空:

 create table student(id int is not null, name varchar(20));

unique: 唯一约束 

创建表的时候,指定列是唯一的,不重复的:

 create table student(id int unique, name varchar(20));

default: 默认值约束

创建表的时候,指定列为空,则插入指定默认值:

create table student(id int, name varchar(20) default '无名氏');

primary key: 主键约束

指定列为主键:

create table student(id int primary key, mame varchar(20));

自增主键: auto_increment, 插入对应数据不给值时,使用最大值+1

 create table student(id int primary key auto_increment, mame varchar(20));

foreign key: 外键约束

外键用于关键其他的表的主键:

注意: 外键约束关键的表的对应列得有主键约束才能使用foreign key

create table student(id int primary key auto_increment, mame varchar(20));
create table score(id int, name varchar(20), student_id int,  foreign key (student_id) references student(id));

check约束(MySQL中不使用它)

MySQL使用会忽略check:

create table student(id int, name varchar(30), check(id = 1 or id = 3));

表的设计

三大范式

一对一

 

一对多

多对多

新增

将一张表已有的数据复制到另一张表中,复制的字段类型需要在被复制表中有的类型

语法:

insert into 表名1(类型1,类型2....) select 类型1, 类型2.... from 表名2; 

栗子:

insert into student1(id,name) select id, name from student2;

查询

聚合查询

聚合函数

一般常用的函数有sum, avg, max, min, count:

函数作用
sum返回查询的行的数据之和,需要是数字
avg返回查询的行的数据的平均值,需要是数字
max返回查询的行的数据的最大值,需要是数字
min返回查询的行的数据的最小值,需要是数字
count返回查询的行数

栗子:

mysql> select * from student;
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+

sum:

mysql> select sum(id) from student;
+---------+
| sum(id) |
+---------+
|      44 |
+---------+

avg:

mysql> select avg(id) from student;
+---------+
| avg(id) |
+---------+
|  5.5000 |
+---------+

max:

mysql> select max(id) from student;
+---------+
| max(id) |
+---------+
|       9 |
+---------+

min:

mysql> select min(id) from student;
+---------+
| min(id) |
+---------+
|       2 |
+---------+

count: 

mysql> select count(*) from student;
+----------+
| count(*) |
+----------+
|        8 |
+----------+

注意: 这里*是查询全部的行数, 括号内可以指定查询字段,字符为null的不会记录

mysql> select count(qq_mail) from student;
+----------------+
| count(qq_mail) |
+----------------+
|              4 |
+----------------+

group by 子句

select使用group by 可以指定列分组查询. 需要满足的条件有: 使用group by 进行分组查询的时候,select 指定的字段得是分组依据的字段, 其他字段要是想出现在select中得包含在聚合函数中

下面栗子中需要查询的数据:

mysql> select * from score;
+-------+------------+-----------+
| score | student_id | course_id |
+-------+------------+-----------+
|    70 |          1 |         1 |
|    98 |          1 |         3 |
|    33 |          1 |         5 |
|    98 |          1 |         6 |
|    60 |          2 |         1 |
|    59 |          2 |         5 |
|    33 |          3 |         1 |
|    68 |          3 |         3 |
|    99 |          3 |         5 |
|    67 |          4 |         1 |
|    23 |          4 |         3 |
|    56 |          4 |         5 |
|    72 |          4 |         6 |
|    81 |          5 |         1 |
|    37 |          5 |         5 |
|    56 |          6 |         2 |
|    43 |          6 |         4 |
|    79 |          6 |         6 |
|    80 |          7 |         2 |
|    92 |          7 |         6 |
+-------+------------+-----------+

栗子:

mysql> select student_id, sum(score) from score group by student_id;
+------------+------------+
| student_id | sum(score) |
+------------+------------+
|          1 |        299 |
|          2 |        119 |
|          3 |        200 |
|          4 |        218 |
|          5 |        118 |
|          6 |        178 |
|          7 |        172 |
+------------+------------+

having

分组后需要对结果进行筛选,不能使用where语句,需要使用having

栗子:

mysql> select student_id, sum(score) from score group by student_id having sum(score) < 200;
+------------+------------+
| student_id | sum(score) |
+------------+------------+
|          2 |        119 |
|          5 |        118 |
|          6 |        178 |
|          7 |        172 |
+------------+------------+

联合查询

在开发中会有很多张表存放数据,这里我们就需要联合查询.联合查询就是对多张表进行笛卡尔积:

初始化数据

mysql> select * from student;
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+
mysql> select * from classes;
+---------+-------------------+-----------------------------------------------+
| classID | name              | desc                                          |
+---------+-------------------+-----------------------------------------------+
|       1 | 计算机系2019级1班 | 学习了计算机原理、C和Java语言、数据结构和算法     |
|       2 | 中文系2019级3班   | 学习了中国传统文学                              |
|       3 | 自动化2019级5班   | 学习了机械自动化                                |
+---------+-------------------+-----------------------------------------------+
mysql> select * from score;
+-------+------------+-----------+
| score | student_id | course_id |
+-------+------------+-----------+
|    70 |          1 |         1 |
|    98 |          1 |         3 |
|    33 |          1 |         5 |
|    98 |          1 |         6 |
|    60 |          2 |         1 |
|    59 |          2 |         5 |
|    33 |          3 |         1 |
|    68 |          3 |         3 |
|    99 |          3 |         5 |
|    67 |          4 |         1 |
|    23 |          4 |         3 |
|    56 |          4 |         5 |
|    72 |          4 |         6 |
|    81 |          5 |         1 |
|    37 |          5 |         5 |
|    56 |          6 |         2 |
|    43 |          6 |         4 |
|    79 |          6 |         6 |
|    80 |          7 |         2 |
|    92 |          7 |         6 |
+-------+------------+-----------+

 

mysql> select * from course;
+----+--------------+
| id | name         |
+----+--------------+
|  1 | Java         |
|  2 | 中国传统文化 |
|  3 | 计算机原理   |
|  4 | 语文         |
|  5 | 高阶数学     |
|  6 | 英文         |
+----+--------------+

内连接

使用方式: 

select 字段 from 表1 别名1 [inner] join 表2 别名2 on 连接条件 and 其他条件;
select 字段 from 表1 别名1,表2 别名2 where 连接条件 and 其他条件;

mysql> select * from student,score where student.id = score.student_id and student.name = '菩提老祖';
+----+-------+----------+---------+----------+-------+------------+-----------+
| id | sn    | name     | qq_mail | class_id | score | student_id | course_id |
+----+-------+----------+---------+----------+-------+------------+-----------+
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    99 |          3 |         5 |
+----+-------+----------+---------+----------+-------+------------+-----------+

 

mysql> select * from student join score on student.id = score.student_id and student.name = '菩提老祖';
+----+-------+----------+---------+----------+-------+------------+-----------+
| id | sn    | name     | qq_mail | class_id | score | student_id | course_id |
+----+-------+----------+---------+----------+-------+------------+-----------+
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖 | NULL    |        1 |    99 |          3 |         5 |
+----+-------+----------+---------+----------+-------+------------+-----------+

外连接

外连接分为左外连接和右外连接.联合查询中左侧的表完全显示为左外连接,右侧完全显示为有外连接

使用方法:

-- 左外连接,表1完全显示
select 字段名 from 表名1 left join 表名2 on 连接条件;
-- 右外连接,表2完全显示
select 字段 from 表名1 right join 表名2 on 连接条件;

mysql> select * from student left join score on student.id = score.student_id;
+----+-------+------------+------------------+----------+-------+------------+-----------+
| id | sn    | name       | qq_mail          | class_id | score | student_id | course_id |
+----+-------+------------+------------------+----------+-------+------------+-----------+
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |    60 |          2 |         1 |
|  2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com  |        1 |    59 |          2 |         5 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    33 |          3 |         1 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    68 |          3 |         3 |
|  3 | 00835 | 菩提老祖   | NULL             |        1 |    99 |          3 |         5 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    67 |          4 |         1 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    23 |          4 |         3 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    56 |          4 |         5 |
|  4 | 00391 | 白素贞     | NULL             |        1 |    72 |          4 |         6 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |    81 |          5 |         1 |
|  5 | 00031 | 许仙       | xuxian@qq.com    |        1 |    37 |          5 |         5 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    56 |          6 |         2 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    43 |          6 |         4 |
|  6 | 00054 | 不想毕业   | NULL             |        1 |    79 |          6 |         6 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |    80 |          7 |         2 |
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |    92 |          7 |         6 |
|  8 | 83223 | tellme     | NULL             |        2 |  NULL |       NULL |      NULL |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |  NULL |       NULL |      NULL |
+----+-------+------------+------------------+----------+-------+------------+-----------+
mysql> select * from student right join score on student.id = score.student_id;
+------+-------+------------+-----------------+----------+-------+------------+-----------+
| id   | sn    | name       | qq_mail         | class_id | score | student_id | course_id |
+------+-------+------------+-----------------+----------+-------+------------+-----------+
| NULL | NULL  | NULL       | NULL            |     NULL |    70 |          1 |         1 |
| NULL | NULL  | NULL       | NULL            |     NULL |    98 |          1 |         3 |
| NULL | NULL  | NULL       | NULL            |     NULL |    33 |          1 |         5 |
| NULL | NULL  | NULL       | NULL            |     NULL |    98 |          1 |         6 |
|    2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com |        1 |    60 |          2 |         1 |
|    2 | 09982 | 黑旋风李逵 | xuanfeng@qq.com |        1 |    59 |          2 |         5 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    33 |          3 |         1 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    68 |          3 |         3 |
|    3 | 00835 | 菩提老祖   | NULL            |        1 |    99 |          3 |         5 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    67 |          4 |         1 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    23 |          4 |         3 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    56 |          4 |         5 |
|    4 | 00391 | 白素贞     | NULL            |        1 |    72 |          4 |         6 |
|    5 | 00031 | 许仙       | xuxian@qq.com   |        1 |    81 |          5 |         1 |
|    5 | 00031 | 许仙       | xuxian@qq.com   |        1 |    37 |          5 |         5 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    56 |          6 |         2 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    43 |          6 |         4 |
|    6 | 00054 | 不想毕业   | NULL            |        1 |    79 |          6 |         6 |
|    7 | 51234 | 好好说话   | say@qq.com      |        2 |    80 |          7 |         2 |
|    7 | 51234 | 好好说话   | say@qq.com      |        2 |    92 |          7 |         6 |
+------+-------+------------+-----------------+----------+-------+------------+-----------+

自连接

自连接就是自己与自己连接查询.

mysql> select * from course c1, course c2 where c1.name = c2.name;
+----+--------------+----+--------------+
| id | name         | id | name         |
+----+--------------+----+--------------+
|  1 | Java         |  1 | Java         |
|  2 | 中国传统文化 |  2 | 中国传统文化 |
|  3 | 计算机原理   |  3 | 计算机原理   |
|  4 | 语文         |  4 | 语文         |
|  5 | 高阶数学     |  5 | 高阶数学     |
|  6 | 英文         |  6 | 英文         |
+----+--------------+----+--------------+

子查询

子查询是指嵌入在其他sql语句中的select语句 

mysql> select * from student where class_id = (select class_id from student where name = 'tellme');
+----+-------+------------+------------------+----------+
| id | sn    | name       | qq_mail          | class_id |
+----+-------+------------+------------------+----------+
|  7 | 51234 | 好好说话   | say@qq.com       |        2 |
|  8 | 83223 | tellme     | NULL             |        2 |
|  9 | 09527 | 老外学中文 | foreigner@qq.com |        2 |
+----+-------+------------+------------------+----------+

合并查询

将多个类型一样的表合并

mysql> select * from course where id < 2 union select * from course where id = 4;
+----+------+
| id | name |
+----+------+
|  1 | Java |
|  4 | 语文 |
+----+------+

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

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

相关文章

一分钟秒懂人工智能对齐

文章目录 1.什么是人工智能对齐2.为什么要研究人工智能对齐3.人工智能对齐的常见方法 1.什么是人工智能对齐 人工智能对齐&#xff08;AI Alignment&#xff09;指让人工智能的行为符合人的意图和价值观。 人工智能系统可能会出现“不对齐”&#xff08;misalign&#xff09;…

Linux--gcc与make

文章目录 gcc/g的使用背景知识gcc与ggcc的编译过程预处理编译汇编链接 函数库自动化构建工具--make三个时间伪目标文件其他表示方法mybin的推导过程 gcc/g的使用 背景知识 GCC是一个开源的编译器套件&#xff0c;支持多种编程语言&#xff0c;并提供了广泛的语言特性和标准库…

真的设计师做图只需要一个炫云客户端就够了

真的设计师做图只需要一个炫云客户端就够了&#xff0c;为什么这么说呢&#xff1f;因为炫云的这个客户端功能真的太全了&#xff0c;设计师想要的功能在炫云客户端上都有&#xff0c;而且还很多功能是免费的&#xff0c;非常的实用&#xff0c;具体有哪些功能我们一起来看看吧…

无人机航迹规划:五种最新智能优化算法(SWO、COA、LSO、GRO、LO)求解无人机路径规划MATLAB

一、五种算法&#xff08;SWO、COA、LSO、GRO、LO&#xff09;简介 1、蜘蛛蜂优化算法SWO 蜘蛛蜂优化算法&#xff08;Spider wasp optimizer&#xff0c;SWO&#xff09;由Mohamed Abdel-Basset等人于2023年提出&#xff0c;该算法模型雌性蜘蛛蜂的狩猎、筑巢和交配行为&…

一键批量转码:将MP4视频转为MP3音频的简单方法

随着数字媒体设备的普及&#xff0c;视频和音频格式转换的需求也越来越常见。其中&#xff0c;将MP4视频批量转换为MP3音频的需求尤为普遍。无论是为了提取视频中的背景音乐&#xff0c;还是为了在手机或电脑上方便地收听视频音频&#xff0c;这个过程都变得非常重要。接下来我…

数字滤波器设计---FIR 滤波器设计

数字滤波器设计---FIR 滤波器设计 FIR 滤波器与 IIR 滤波器的比较 与无限持续时间冲激响应 (IIR) 滤波器相比&#xff0c;具有有限持续时间冲激响应的数字滤波器&#xff08;全零或 FIR 滤波器&#xff09;既有优点又有缺点。 FIR 滤波器具有以下主要优点&#xff1a; 它们可…

Java中的反射机制

获取字节码文件对象的三种方式 1&#xff0c;&#xff08;常用&#xff09;源代码阶段&#xff0c;Class.forName("全类名") 2&#xff0c;&#xff08;传参&#xff09;加载阶段 类名.class 3&#xff0c;&#xff08;前提有对象&#xff09;运行阶段 对象.getClas…

LeetCode算法心得——全排列(回溯型排列)

大家好&#xff0c;我是晴天学长&#xff0c;排列型的回溯&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .全排列 给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按…

外贸企业GMS认证|SD-WAN专线解决方案支持 IPv6、IPv4

IP地址是英文internet protocol的缩写&#xff0c;是网络之间互连的协议。互联网诞生后&#xff0c;很长一段时间都是使用v4版本的IP协议&#xff0c;也就是 IPv4 &#xff0c;目前全球使用互联网的人数达到了48.8亿&#xff0c;而IPv4的地址库总共约43亿个地址&#xff0c;每个…

CCLink转Modbus TCP网关_MODBUS报文配置

兴达易控CCLink转Modbus TCP网关是一种功能强大的设备&#xff0c;可实现两个不同通信协议之间的无缝对接。它能够将CCLink协议转换为Modbus TCP协议&#xff0c;并通过报文配置实现灵活的通信设置。兴达易控CCLink转Modbus TCP网关可以轻松实现CCLink和Modbus TCP之间的数据转…

竞赛 车道线检测(自动驾驶 机器视觉)

0 前言 无人驾驶技术是机器学习为主的一门前沿领域&#xff0c;在无人驾驶领域中机器学习的各种算法随处可见&#xff0c;今天学长给大家介绍无人驾驶技术中的车道线检测。 1 车道线检测 在无人驾驶领域每一个任务都是相当复杂&#xff0c;看上去无从下手。那么面对这样极其…

2011年09月06日 Go生态洞察:Go语言的反射法则

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

STM32——STM32F4系统架构

文章目录 前言STM32F4XX系统架构 前言 本篇文章为STM32F4系列的系统架构&#xff0c;因为最近在学习F4的板子&#xff0c;暂时先更F4的&#xff0c;有需要F1的后续再更新。 主系统由 32 位多层 AHB 总线矩阵构成&#xff0c;可实现以下部分的互连&#xff1a; STM32F4XX系统架…

(自适应移动端)响应式门窗定制pbootcms板 门窗门业网站板下载-带视频功能

(自适应移动端)响应式门窗定制pbootcms模板 门窗门业网站模板下载-带视频功能 PbootCMS内核开发的网站模板&#xff0c;该模板适用于门窗门业网站等企业&#xff0c;当然其他行业也可以做&#xff0c;只需要把文字图片换成其他行业的即可&#xff1b; 自适应移动端&#xff0c;…

款网络拓扑自动扫描工具

Topology-Scanner是WeOps团队免费开放的一个网络拓扑自动扫描模块&#xff0c;可以自动发现网络设备的类型、网络设备之间的互联 使用方式 java -jar ./topology-scanner.jar --config_path./config/ 配置说明 1. 拓扑发现请求参数文件(request.json) ips [全网发现] 模式时…

2023/11/10 JAVA学习

取文件夹本身大小 打开文件 文件改名案例 输出流,文件依照你起的文件名自动创建 哪个流后创建,哪个流先关闭 虚拟机退出跑不了 finally别返回值

记一次上位机软件线程泄露的分析及解决

上位机软件在客户现场隔一段时间说操作了没反应&#xff0c;但是上位机又没死&#xff0c;出现了一些奇怪现象&#xff1a; 左上角的时间不走了&#xff08;本来是1s运行一次&#xff09;使用任务管理器查看&#xff0c;内存占用1.5G,线程有3000多个&#xff0c;正常情况下&am…

【chat】2:vs2022 连接远程ubuntu服务器远程cmake开发

大神们是使用vs远程连接和调试的:C++搭建集群聊天室(三):配置远程代码编辑神器 VScode我尝试过vs++ 和 clion 都不错。在 Visual Studio 中配置 Linux CMake 项目 比较麻烦的就是要配置CMakeSettings.json ,而且会自动做复制指定远程 Linux 目标,则会将源复制到远程系统 …

【K8s集群离线安装-kubeadm】

1、kubeadm概述 kubeadm是官方社区推出的一个用于快速部署kubernetes集群的工具。这个工具能通过两条指令快速完成一个kubernetes集群的部署。 2、环境准备 2.1 软件环境 软件版本操作系统CentOS 7Docker19.03.13K8s1.23 2.2 服务器 最小硬件配置&#xff1a;2核CPU、2G内存…

软件研发团队适用的项目管理工具推荐

Zoho Projects是一款专为大型产研团队设计的项目管理工具&#xff0c;它也是许多软件开发行业高速成长背后的生产线。与其他项目管理产品相比&#xff0c;Zoho Projects最大的不同之处在于其独特的流程设计。在软件上线初期&#xff0c;Zoho Projects能够有效地帮助软件研发公司…