接口测试 02 -- JMeter入门到实战

前言

JM eter毕竟是做压测的工具,自动化这块还是有缺陷。
如果公司做一些简单的接口自动化,可以考虑使用JMeter快速完成,如果想做完善的接口自动化体系,建议还是基于Python来做。
为什么学习接口测试要先从JMeter开始?
工作中,并不是一开始我们就写代码来测接口
只有接口通了,才能开始做接口自动化
即便真的不需要做功能测试,但是做自动化之前,务必要先确保单接口已经调调试通了( JMeter、poastam)

1. JMeter简介及安装

1.1 JMeter的优点

● JMeter是基于Java的开源工具,扩展性强,可自定义开发插件;
● JMeter社区活跃,会定期更新、修改bug、优化功能;
● JMeter学习成本低,提供了方便的图形界面来编辑和开发测试脚本,上手快;
● JMeter可以和很多工具兼容,如Jenkins,方便测试自动化;
● JMeter具有平台无关性,可以轻易在Windows、Linux和macOS上运行。

 1.2 JMeter的安装

① 安装JDK

从官网下载JDK: https://www.oracle.com/cn/java/technologies/download
s/#java8-windows (需要注册)
嫌麻烦的话,可以从这里下:
https://pan.baidu.com/s/15PE5vikEHhma-2rEcjjSzA?pwd=zh57
这是一个其他人帅心善的博主提供的资源,这里借花献佛咯
以下是博主的JDK详细的安装教程:
[ 环境搭建篇 ] 安装 java 环境并配置环境变量(附 JDK1.8 安装包)_如何安装环境1.8-CSDN博客
或者我的这篇文章中也有介绍JDK安装: pytest -- 进阶使用详解-CSDN博客

② 安装JMeter(windows)

从官网下载JMeter的Binaries版本(可执行的版本),另外一个Source版本是源码,需要自己编译,需注意区别,别下载错了。
官网地址: https://jmeter.apache.org/download_jmeter.cgi

进入官网:点击下载

下载好之后解压文件 -> 运行/bin目录下的 jmeter.bat

即可打开JMeter的图形化界面进行脚本的编写。

建议放在c盘(不用配置环境变量),我尝试了放在D盘,配置环境变量怎么配都启动不了

启动后:会出现左边的cmd,使用过程中不要关闭cmd,关闭了cmd就相当于关闭了jmeter

③ jmeter界面设置

初次启动,界面上的字体小的感人,眼睛快戳瞎了……

界面调整:

中文模式:

但是关掉重启之后,又恢复了一开始那么小的字体、语言又显示成了英文

 找到JMeter的配置文件jmeter.properties,用记事本打开,修改字体设置,找到这两行代码:

前两行默认是注释掉的,把前面的#去掉,最后一行放开并修改后面的数字

jmeter.hidpi.mode=true   #放开
jmeter.hidpi.scale.factor=2.0   #放开
jmeter.hidpi.scale.factor=2.357948  #放开并修改后面的数组

waht?再重新打开还是这么小

然后重新点一下放大,就不需要点很多次,点一次就这么大了

凑合着用吧,目前没找到一次修改配置能够永久性设置的方法

修改语言为中文:配置文件jmeter.properties找到language=这行,改为:下面第一行这样

Preferred GUI language. Comment out to use the JVM default locale's language.
language=zh_CN#Preferred GUI language. Comment out to use the JVM default locale's language.
#language=en  这是原本的

重新打开,文字显示为中文了

1.3JMeter常用的核心组件介绍

由于JMeter涉及的组件数目很多,据不完全统计至少有110个,而其实只需要掌握 20%的组件就可以完成80%甚至更多的日常工作了,所以接下来我们重点学习使用最频繁的核心组件,只需要优先掌握这10个左右的组件就能应付日常大部分的接口测试工作。
---------------->>>
注意:
(1)所有组件的添加都是通过鼠标右键单击上一层组件的方式选择的。
(2)比较好用的功能是使用鼠标右键单击做启用(enable)或禁用(disable)的切换,对于不想测试的请求可以禁用,而不用删除处理。

Jmeter常用组件的功能

① 测试计划:测试起点,所有组件的容器
② 线程组:代表一定数量的用户
③ 取样器:向服务器发送请求的最小单元
④ 逻辑控制器:结合取样器实现一些复杂的逻辑
⑤ 前置处理器:在请求之前的工作
⑥ 后置处理器:在请求之后的工作
⑦ 断言:判断请求是否成功
⑧ 定时器:负责请求之间的延迟间隔。常用的有固定,高斯,随机
⑨ 配置元件:配置信息
⑩ 监听器:收集结果
------------------->>>
执行顺序:
测试计划 -> 线程组 -> 配置元件 -> 前置处理器 -> 定时器 -> 取样器(请求)-> 后置处理器-> 断言 -> 监听器
作用域:
必须组件:测试计划、线程组、取样器
辅助组件:剩余的
辅助组件作用于父组件,同级组件以及同级组件下的所有子组件

前、后置处理,对应的页面按钮: 


2. 使用jemter接口测试实战

2.1 接口请求分析

目标网站接口信息

以下根据目标网站的注册接口为例:进行接口分析 -> 接口测试

 ● 目标网站域名:http://xxx.com?

 ● 目标网站公共参数

目标网站注册_请求urlapi/user/reg

目标网站注册_请求参数:

参数名
是否必须
类型
默认值
描述
accounts
string
用户名
pwd
string
密码
type
string
类型

公共参数是所有接口都必须带的参数,请求参数对应每个具体接口的参数


接口分析

接口请求四要素

在文档当中找:接口URL、请求方法、请求参数、响应数据

在工作当中:token字段一般是放在对应的请求头(header)

目标网站比较特殊,项目token在url当中(最后面)

目标网站解析:http://xxx.com?

  • s=api/user/login
  • application === app
  • application_client_type=== weixin

根据规则拼凑出一个完整的注册接口:

接口URL : 协议+域名+路径 + 公共参数(用&拼接)

http://xxx.com?s=api/user/reg&application=app&application_client_type=weixin

----------->>>

看到注册接口的请求方式是post,我们第一反应要清楚:

● post请求的请求参数是放在body中的

● body请求参数,与请求头的content-type是一一对应的

body请求数据类型:

那么问题来了:

body的请求数据类型(如上图)有那么多,我们怎么确定是哪一种呢?

● 有些接口文档会注明,它是什么请求类型:那么直接选择即可

● 如果接口文档没写:

        一般默认用form表单提交 (字段相对比较少):x-www-form-urlencoded
        提交需带有对应的图片: from-data
        字段非常多,或者它的数据是{xXXX: XXXX}:raw-json

所有的工具也都是这个规则

得到请求参数(目标网站的body格式josn)

type有手机号、邮箱、自定账号;这里我们使用自定义账号,即username

{accounts":"username",
"pwd":"password",
"type":"username" }

响应数据:

上面我们已经清楚了注册接口的请求url、请求方法、请求参数及body数据类型,根据请求信息,我们就能得到一个请求结果了。

那么根据这个请求,我们期望得到的结果是什么呢?

期望结果:

1. 输入正确的数据:注册成功
2. 输入已经存在的数据:账号已存在测试用例设计

……

这就类似于测试用例设计

请求参数不同数据的组合,得到的对应的结果

考虑正向场景、异常场景,和功能测试的设计思路一致

注册接口测试用例示例 


2.2 单个执行接口测试用例

jmeter执行接口测试用例,详细步骤如下:

① 添加线程组

jmeter属于半自动工具,需要有人的介入,一定数量的用户表示一个【线程组】

右击【测试计划】--> 添加 --> 添加线程组:

② 添加取样器

我们需要做什么?发送一个接口请求:【取样器】

在JMeter中,虽然在取样器的类型中只有HTTP,但是它可以发送HTTPS请求。

要发送HTTPS请求,只需在HTTP请求中指定协议为HTTPS,即在服务器名称或IP地址前加上"https://"前缀。在HTTP请求中,可以使用如下格式的URL来发送HTTPS请求:https://www.example.com 或 https://192.168.0.1。

右键【线程组】右击 --> 添加 --> 选择HTTP请求(我们这里是接口请求属于http) 

 ③ 填写请求信息

上面我们得到的注册接口完整的url是:

http://xxx.com?s=api/user/reg&application=app&application_client_type=weixin

路径从?开始,截图中漏了

④ 添加监听器

添加监听器,是为了方便执行后查看结果

右键接口名 --> 添加 --> 监听器 --> 查看结果树

⑤ 执行接口测试: 

上面截图字打错了,是保存;根据个人需要,也可以不保存 

点击保存后,等1~2秒即出来执行结果:

响应中显示的响应结果,对应这个接口请求的实际结果

测试用例的结果,是我们的期望结果

当然实际工作中,我们不可能一个个点进去,肉眼去确认接口返回的实际结果

那么:我们可以通过添加断言,来看接口的返回是否和我们的期望结果一致

⑤ 添加断言

比如,我就想断言这个注册接口返回的响应josn信息中,msg是否为注册成功

需要对哪个接口进行断言,就右键对应的接口 --> 添加 --> 断言 --> 选择JSON断言

JSON断言中,默认使用的是JOSN path,这个json path填写有一定的规则 

可以先取查看结果树种测试一下,写的对不对,具体见下图备注:

填写断言信息:

重新执行一遍:

查看断言信息、断言失败(只有失败了下面才会显示断言,成功的话不会显示短信信息)

2.3 多个接口执行测试用例

基于上面的注册接口之后,再新建一个登陆接口(即再加一个取样器)

登陆接口请求url:api/user/login

登陆请求参数:与注册一致

jmeter配置原件 

大家可能已经发现了一个问题,就是每增加一个接口,都需要再填一遍HTP请求信息,是不是很麻烦?如果哪天请求的域名变了,那么是不是几十个、几百个接口都得改一遍?那么有没有简单的方法呢?

----------------->>>>

是的,有更简单的方法,就是使用【配置原件】这个功能:

我们的接口是HTTP,那么就选择 HTTP请求默认值 

把域名和协议类型,填在默认请求页面里

下面的注册 和 登陆接口页面中的 域名和协议类型就可以删掉了

重新运行一下:

设置环境变量

根据上面的配置原件使用思路,同理可得:

特别适用于环境切换的修改,比如有测试环境、生产环境,有100个接口

我不需要再两个环境中都去各写100遍接口,只需要加一个【请求默认值】,根据不同环境的域名填写即可

执行哪个环境,就把另一个环境给禁用掉;

比如现在我要在测试环境,把就把生产环境的禁用

禁用后,它的字体颜色就变浅了

设置变量

即用户定义的变量

比如我基于上面测试用例中一个用户名、密码注册好之后,我还需要再次注册账号,那么每换一个不同的账号注册,注册和登陆HTTP请求信息的页面中,都需要取改对应的用户名、密码,是不是也很麻烦?

------->>>

so,偷懒的办法:就是添加一个【用户定义的变量】

定义变量:

在【用户定义的变量】 中定义账号、密码

引用变量:

重新运行一下:可以看到,注册和登陆都成功了

所以:

定义变量,适合请求参数中的某些字段值是经常要变的,就不要固定写死,把它提取出来,放在用户变量里,运行的时候动态来取值引用;

改的时候也只有改一处,其他地方不用动,非常方便


2.4 Jmeter数据驱动测试

数据驱动测试,也叫DDT

--------------->>>>>

例如:上面的excel截图中,一个登陆接口,我们有多种场景需要测试

共同点是:请求URL相同

不同点是:请求参数不同

那么我们能不能把接口数据提取出来?当然可以

再新建一个线程组,可以使用复制黏贴的方式:

选中登陆&注册--ctrl+c  --> 点击测试测试计划  ctrl+v即可

然后把登陆&注册这个case禁用掉:点击登陆&注册 右键 --> 禁用即可

准备数据:

在桌面新建一个文件夹:

这里使用Notepad++这个软件(它不会带任何格式),编写登陆接口的不同测试场景

注意:使用英文逗号,不用加双引号把字符串引起来,jmeter也可以处理

添加配置元件 --> csv

配置csv文件信息

添加循环控制器

因为是一个接口对应4条用例,需要让它循环来执行:

数据驱动tab右键 --> 添加 --> 逻辑控制器  --> 选择‘循环控制器’

注意层级关系:需要让jmeter循环读数据,然后循环进行登录,

所以把数据文件配置、 登陆接口拖到循环控制器的下面

并且在循环控制器中,修改循环次数(根据自己的用例条数,是几条写几)

修改断言

执行测试用例

上面的逐步都配置好了之后,就可以运行用例了

下面三条用例为什么失败了呢?

是因为断言里的预期结果的文案与接口文档中的不一致,需要一致才行

重新修改一下文件中的期望结果文案、重新执行一下,然后全部成功

结果查看--优化

因为上面我们的场景是一个接口对应多条测试用例,当我们运行完之后,没法第一眼就知道哪条结果对应那条用例,所以我们可以在接口名称后面也加一个变量引用:

重新运行一下:查看结果时,清晰明了


2.5 Jmeter接口关联测试

接口关联,可以理解为接口的上下游操作之间的依赖

例如:一个电商平台

1、需要先登陆

2、通过登陆之后选购商品加入到购物车

3、……

=====================================================================

在接口测试中,需要解决的是哪个登录用户的问题,也就是说加入购物车的时候,怎么知道是哪个用户。

鉴别用户身份,通用的方法就是Token(软件中临时身份证号,代表某个具体的账号)

token怎么来的?一般在登陆之后,会在响应数据、或者请求头中

看看上面运行登录接口的接口, token在响应数据的body中

1、需要先登陆:得到token:226795e8cbc5ff159f6befb645b1ee01

2、通过登陆之后选购商品加入到购物车:请求数据需要加上token

3、……

一般token放在head里,但是也有特殊的,是需要直接放在请求url的最后,比如现在这个目标网站就是需要放在url里

=====================================================================

总结来说:

上一个接口的响应数据(token值),作为下一个接口的请求数据(token = token值)

添加后置处理器

前面有了解过,后置处理器,就是处理在请求之后的工作

配置josn提取器

添加下游接口

添加配置信息头管理器

在 JMeter 中,HTTP信息头管理器用于管理 HTTP 请求中的请求头信息。

HTTP 请求头包含了一些关于请求的元数据,例如用户代理、内容类型、授权信息等。

通过使用 HTTP信息头管理器,可以方便地管理这些请求头信息,以便在测试计划中的多个 HTTP请求中重复使用。

具体来说,HTTP信息头管理器可以用于以下几个方面:

  1. 添加通用的请求头信息:可以在 HTTP信息头管理器中添加常用的请求头信息,例如 User-Agent、Accept、Content-Type 等,以便在测试计划中的多个 HTTP请求中重复使用这些信息。

  2. 管理授权信息:可以在 HTTP信息头管理器中添加授权信息,例如 Basic 认证的 Authorization 头部,以便在多个请求中使用相同的授权信息。

  3. 管理自定义的请求头信息:可以在 HTTP信息头管理器中添加自定义的请求头信息,以满足特定的测试需求。

这里,我们添加HTTP信息头管理器的目的:是因为josn格式的body请求信息,需要与请求头当中的 Content-Type一一对应

设置content-type的格式为:application/ison(请求参数格式为josn)

运行接口用例:

接口关联--总结:

1. 上一个接口的响应数据,作为下一个接口的请求数据(比如token)

2. 如果请求参数的数据格式是json,务必要添加配置信息头管理器,设置json格式


2.6 JDBC驱动及数据断言

JMeter中如果要用SQL语句查询数据库,就需要用到JDBC请求和JDBC Connection Configuration了。

也可以作为数据驱动测试的另外一种方式

------------->>>

在测试过程中,对于数据库的操作场景一般有
● 测试数据的制造
● 查询数据用于测试的输入
● 测试完成之后查询数据用于检测结果
● 业务SQL的性能测试

数据库连接JDBC驱动下载

打开MySQL JDBC的下载网站:
https://downloads.mysql.com/archives/cj/,并选择操作系统: Platform Independent。

点击 DOWNLOADS,把页面滚动到最下面,点击 MySQL Community (GPL) Downloads

点击 Connector/J ----进入后选择Platform Independent ---选择zip格式(windows系统选zip)

注意下载驱动的版本要与mysql的版本相匹配,如果驱动版本比msql版本高,可能用不了

点击下载:

下载后,将mysql-connector-java-5.1.48-bin.jar这个文件放到jmeter的bin目录下

Jmeter中关联jar包

点击测试计划 --> 浏览 --> 选中jar包 --> 点击open

必须引用jar包,不然执行会报错

配置连接数据库的配置信息

选择要添加的线程组 --> 添加 --> 配置元件 --> 选择JDBC Connection Configuration

添加JDBC请求配置

JDBC Connection Configuration页面:相当于mysql的链接信息配置 

拉到最下面,把数据库连接的4项信息填上 

Database URL:dbc:mysql://xx域名:3306/数据库地址  (3306是端口号)

添加配置JDBC Request

注意层级关系,把它拖到循环控制器的下面

引用JDBC Connection Configuration中的数据库名字

正常写sql就行 

上面的【HTTP请求默认值】不变(协议、域名),还是使用上面的测试网址信息

【用户定义的变量】,变量信息指明,账号与密码为前面已注册成功的

添加一个【HTTP请求】 ,请求名称使用上面的SQL查询结果变量

【用户定义的变量】中指定了账号与密码的变量,所以使得【JDBC Request】中的查询结果就是查询变量中的账号/密码:

登陆接口基于【JDBC Request】的查询结果,拿到的账号密码执行登录,所以执行成功

这就是为什么登录接口的名称中要引用查询的变量

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

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

相关文章

卡尔曼滤波增益推导

该文章主要是记录温习卡尔曼滤波算法理论时的一些理解,重点讲解卡尔曼增益的推导过程。其中忽略了部分基础知识和详细的推导过程,阅读该文章需要本身已具备卡尔曼滤波基础。文章内容摘取自网络博客的部分内容,因为原文章的逻辑不是很通顺&…

NLP论文阅读记录 - 2021 | WOS 基于多头自注意力机制和指针网络的文本摘要

文章目录 前言0、论文摘要一、Introduction1.1目标问题1.2相关的尝试1.3本文贡献 二.问题定义和解决问题的假设问题定义解决问题的假设 三.本文方法3.1 总结为两阶段学习3.1.1 基础系统 3.2 重构文本摘要 四 实验效果4.1数据集4.2 对比模型4.3实施细节4.4评估指标4.5 实验结果4…

python222网站实战(SpringBoot+SpringSecurity+MybatisPlus+thymeleaf+layui)-帖子详情页实现

锋哥原创的SpringbootLayui python222网站实战: python222网站实战课程视频教程(SpringBootPython爬虫实战) ( 火爆连载更新中... )_哔哩哔哩_bilibilipython222网站实战课程视频教程(SpringBootPython爬虫实战) ( 火…

解决一个mysql的更新属性长度问题

需求背景: 线上有一个 platform属性,原有长度为 varchar(10),但是突然需要填入一个11位长度的值;而偏偏这个属性在线上100张表中有50张都存在,并且名字各式各样,庆幸都包含 platform;例如 platf…

非科班转码的秋招复盘:地理信息科学GIS专业到后端研发、软件开发

本文介绍地理信息科学(GIS)专业的2024届应届生,在研三上学期期间,寻找后端研发、软件开发等IT方向工作的非科班转码秋招情况。 首先,这篇文章一开始写于2023年年底,当时为了参加一个征文活动,所…

Python爬虫的9个具体应用场景案例分析与具体应用。

文章目录 前言一、新闻采集二、数据挖掘三、网站监测四、舆情分析五、爬虫定制化开发六、数据采集与处理七、网络安全八、网络营销九、自动化测试关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①P…

嵌入式学习-网络编程-Day6

嵌入式学习-网络编程-Day6 一、思维导图 二、作业 1.基于UDP的网络聊天室(2024.1.21号前上交) 项目需求: 1.如果有用户登录,其他用户可以收到这个人的登录信息 2.如果有人发送信息,其他用户可以收到这个人的群聊信…

LabVIEW振动数据采集与分析系统

在这个项目中, LabVIEW软件配合精确的硬件组件,以实现高效的振动数据采集和复杂信号分析。硬件方面,系统采用了PCB振动加速度传感器的高灵敏度传感器,以及NI9234型号的数据采集卡,确保了数据采集的高精度和可靠性。软件…

Leetcode刷题-(6~10)-Java+Python+JavaScript

算法题是程序员的基本功,也是各个大厂必考察的重点,让我们一起坚持写算法题吧 遇事不决,可问春风,春风不语,即是本心。 我们在我们能力范围内,做好我们该做的事,然后相信一切都事最好的安排就…

JAVAEE出街 网络编程(一)

网络编程 一. 网络编程二. 客户端与服务器2.1 一问一答2.2 一问多答2.3 多问一答2.4 多问多答 三. TCP与UDP的特点 一. 网络编程 网络编程本质上就是学习传输层给应用层提供的API,把数据交给传输层,通过一层层的封装将数据通过网卡传输出去。 二. 客户端…

html5实现好看的年会邀请函源码模板

文章目录 1.设计来源1.1 邀请函主界面1.2 诚挚邀请界面1.3 关于我们界面1.4 董事长致词界面1.5 公司合作方界面1.6 活动流程界面1.7 加盟支持界面1.8 加盟流程界面1.9 加盟申请界面1.10 活动信息界面 2.效果和源码2.1 动态效果2.2 源码目录结构 源码下载 作者:xcLei…

使用 FFmpeg 轻松调整视频的大小/缩放/更改分辨率

在此 FFmpeg 教程中,我们学习使用 FFmpeg 的命令行工具更改视频的分辨率(或调整视频的大小/缩放)。 更改视频的分辨率(也称为调整大小或缩放)是视频编辑、处理和压缩中非常常见的操作。对于 ABR 视频流尤其如此&#…

HCIP BGP选路实验

拓扑图&IP划分如下: 第一步,配置IP&环回地址 以R1为例,R2~R8同理 interface GigabitEthernet 0/0/0 ip address 12.0.0.1 24 interface LoopBack 0 ip address 10.0.0.1 24 第二步:对AS200网段配置OSPF协议 以R2为例&a…

[C#]C# winform部署yolov8目标检测的openvino模型

【官方框架地址】 https://github.com/ultralytics/ultralytics 【openvino介绍】 OpenVINO(Open Visual Inference & Neural Network Optimization)是由Intel推出的,用于加速深度学习模型推理的工具套件。它旨在提高计算机视觉和深度学…

【使用 UCF101 数据集】C3D 模型准备与模型训练

一、前言 本文章将对 C3D 模型进行解析,对里面的模型结构进行详解,最后使用UCF101 数据集对该模型进行实战,在进行推理时能够正确识别出未知视频中里面正确的类别。 二、目录 三、相关内容 四、详细介绍 【使用 UCF101 数据集】C3D 模型准…

HCIA——20应用层:C/S、P2P、peer

学习目标: 计算机网络 1.掌握计算机网络的基本概念、基本原理和基本方法。 2.掌握计算机网络的体系结构和典型网络协议,了解典型网络设备的组成和特点,理解典型网络设备的工作原理。 3.能够运用计算机网络的基本概念、基本原理和基本方法进行…

基于LabVIEW的压力传感器测试系统

摘要 现在各类压力传感器已广泛应用于各种工业自控环境,对压力传感器的研究 及应用,既可以体现一个国家的科技发展水平,又可以提升国家的综合国力,还 可以在丰富、方便和智能化人们的生活方面做出重要的贡献。而针对不同仪器组 成…

电脑监视软件(2024年最新电脑监控软件推荐)

在当今数字化的时代,电脑已经成为了我们生活和工作中不可或缺的工具。然而,随着电脑使用的普及,人们对于电脑安全的关注也日益增强。 为了保护个人隐私和企业机密,电脑监视软件应运而生。 本文将为您介绍2024年最新电脑监控软件的…

GO 中高效 int 转换 string 的方法与高性能源码剖析

文章目录 使用 strconv.Itoa使用 fmt.Sprintf使用 strconv.FormatIntFormatInt 深入剖析1. 快速路径处理小整数2. formatBits 函数的高效实现 结论 Go 语言 中,将整数(int)转换为字符串(string)是一项常见的操作。 本文…

MySQL---单表查询综合练习

创建emp表 CREATE TABLE emp( empno INT(4) NOT NULL COMMENT 员工编号, ename VARCHAR(10) COMMENT 员工名字, job VARCHAR(10) COMMENT 职位, mgr INT(4) COMMENT 上司, hiredate DATE COMMENT 入职时间, sal INT(7) COMMENT 基本工资, comm INT(7) COMMENT 补贴, deptno INT…