使用ecs服务器进行mysql操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 描述使用ecs服务器进行云开发的过程
  1. 创建szu_test数据库

在服务器后台命令行中使用命令登录进数据库
mysql -h localhost -u szu_test -p

查看系统中有哪些数据库,并使用szu_test数据库

一开始数据库是空的

  1. 建立DEPT表格

导入数据dept
 Sql语句

  1. INSERT INTO DEPT (DEPTNO,DNAME,LOC)
  2. VALUES
  3. (10 , 'ACCOUNTING' ,'LONDON'),
  4. (20 , 'RESEARCH' ,'PRESTON'),
  5. (30 , 'SALES' ,'LIVERPOOL'),
  6. (40 , 'OPERATIONS' ,'STAFFORD'),
  7. (50 , 'MARKETING' ,'LUTON');

 查看导入的情况

  1. 建立EMP表格

 导入数据emp
(由于文字太多,这里采用图片显示)
 Sql语句

 查看导入的情况

2、完成EXERCISES 1 对表格的操作,1-21题

 题目:
List all information about the employees.
 解析:
这个题目要求我们列出所有的员工信息
 结果:

  1. SELECT * FROM EMP;

 题目:
List all information about the departments
 解析:
列出所有部门的信息
 结果:

  1. SELECT * FROM DEPT;

 题目:
List only the following information from the EMP table ( Employee name, employee number, salary, department number)
 解析:
选择出特定的几个字段
 结果:

  1. SELECT
  2. EMPNO, ENAME,SAL, DEPTNO
  3. FROM EMP;

 题目:
List details of employees in departments 10 and 30.
 解析:
条件查询,用or来表明逻辑关系
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE DEPTNO=10 or DEPTNO=30;

5.
 题目:
List all the jobs in the EMP table eliminating duplicates.
 解析:
使用distinct特殊字来对查找出的内容进行去重
 结果:

  1. SELECT
  2. distinct JOB
  3. FROM EMP;

 题目:
What are the names of the employees who earn less than £20,000?
 解析:
(条件小于)查询
 结果:

  1. SELECT ENAME
  2. FROM EMP
  3. WHERE SAL<20000;

7.
 题目:
What is the name, job title and employee number of the person in department 20 who earns more than £25000?
 解析:
And条件查询
 结果:

  1. SELECT EMPNO, ENAME, JOB
  2. FROM EMP
  3. WHERE DEPTNO=20
  4. and SAL> 25000;

 题目:
Find all employees whose job is either Clerk or Salesman.
 解析:
or条件查询,判断字符串相等
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE JOB='Clerk'
  4. or JOB='Salesman';

 题目:
Find any Clerk who is not in department 10.
 解析:
and 条件查询
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE DEPTNO!=10
  4. and JOB='Clerk';

 题目:
Find everyone whose job is Salesman and all the Analysts in department 20.
 解析:
使用括号的多层逻辑查询
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE (JOB='Salesman')
  4. or (JOB='Analyst'and DEPTNO=20);

 题目:
Find all the employees who earn between £15,000 and £20,000.
Show the employee name, department and salary.
 解析:
使用 BETWEEN AND关键字进行查询,找出SAL字段在某个区间的数据
 结果:

  1. SELECT ENAME, SAL, DEPTNO
  2. FROM EMP
  3. WHERE
  4. SAL BETWEEN 15000 AND 20000;

 题目:
Find the name of the President.
 解析:
条件查询
 结果:

  1. SELECT ENAME
  2. FROM EMP
  3. WHERE JOB='President';

 题目:
Find all the employees whose last names end with S
 解析:
使用like关键字来进行特定字符结尾的查询
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE ENAME like '%S';

 题目:
List the employees whose names have TH or LL in them
 解析:
使用like关键字来进行特定字符结尾的or逻辑查询
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE ENAME like '%th%'
  4. or ENAME like '%ll%';

 题目:
List only those employees who receive commission.
 解析:
条件查询,判断COMM字段不为空
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE COMM is not null;

 题目:
Find the name, job, salary, hiredate, and department number of all employees by alphabetical order of name.
 解析:
将查询结果用order by关键字排序
 结果:

  1. SELECT ENAME, JOB, HIREDATE, SAL, DEPTNO
  2. FROM EMP
  3. order by ENAME;

 题目:
Find the name, job, salary, hiredate and department number of all employees in ascending order by their salaries.
 解析:
将查询结果用order by关键字排序
 结果:

  1. SELECT ENAME, JOB, HIREDATE, SAL, DEPTNO
  2. FROM EMP
  3. order by SAL asc;

 题目:
List all salesmen in descending order by commission divided by their salary.
 解析:
将查询结果用order by和 desc关键字降序排序
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE JOB='salesman'
  4. order by COMM/SAL
  5. desc;

 题目:
Order employees in department 30 who receive commision, in ascending order by commission
 解析:
and逻辑查询,并且将结果按comm进行升序排序
 结果:

  1. SELECT * FROM EMP
  2. WHERE DEPTNO=30 and COMM is not null
  3. order by COMM
  4. asc;

 题目:
Find the names, jobs, salaries and commissions of all employees who do not have managers.
 解析:
判断某个字段非null,进行查询
 结果:

  1. SELECT ENAME, JOB, SAL, COMM
  2. FROM EMP
  3. WHERE MGR is null;

 题目:
Find all the salesmen in department 30 who have a salary greater than or equal to £18000.
 解析:
多条件and逻辑查询,并将结果按升序排序
 结果:

  1. SELECT *
  2. FROM EMP
  3. WHERE JOB='salesman'
  4. and DEPTNO=30
  5. and SAL>=18000
  6. ORDER BY COMM asc;

3、完成EXERCISES 2对表格的操作,1-6题

 题目:
Find the name and salary of employees in Luton.
 解析:
多表连接查询,首先利用逻辑EMP.deptno = DEPT.deptno,将两张表对应位置合并,再根据loc字段来进行查询,最终找到所有loc=Luton的雇员
 结果:

  1. SELECT ename, sal
  2. FROM EMP, DEPT
  3. WHERE loc = 'LUTON'
  4. AND EMP.deptno = DEPT.deptno;

 题目:
Join the DEPT table to the EMP table and show in department number order.
 解析:
多表连接查询,首先利用逻辑EMP.deptno = DEPT.deptno,将两张表对应位置合并,再根据deptno字段进行排序
 结果:

  1. SELECT empno, ename, job, mgr, hiredate, sal, comm, DEPT.deptno, DEPT.dname, DEPT.loc
  2. FROM EMP, DEPT
  3. WHERE EMP.deptno = DEPT.deptno
  4. ORDER BY deptno;

 题目:
List the names of all salesmen who work in SALES
 解析:
连接查询,查找出所有在sales工作的saleman
 结果:

  1. SELECT ename
  2. FROM EMP , DEPT
  3. WHERE job = 'SALESMAN'
  4. AND dname = 'SALES';

 题目:
List all departments that do not have any employees.
 解析:
 多级查询,首先利用DEPT.deptno = EMP.deptno语句将emp和dept两表连接,查询出deptno字段作为集合,在集合中利用deptno字段查找出没有任何雇员的部门,
 结果:

  1. SELECT DEPT.deptno
  2. FROM DEPT
  3. WHERE deptno NOT IN (
  4. SELECT DEPT.deptno
  5. FROM DEPT, EMP
  6. WHERE DEPT.deptno = EMP.deptno
  7. );

 题目:
For each employee whose salary exceeds his manager's salary, list the employee's name and salary and the manager's name and salary.
 解析:
利用worker.mgr=manager.empno语句将两表连接,再根据条件进行查询worker.sal > manager.SAL
 结果:

  1. SELECT worker.ename,worker.sal,manager.ename,manager.sal
  2. FROM EMP worker,EMP manager
  3. WHERE worker.mgr=manager.empno
  4. AND worker.sal > manager.SAL;

 题目:
List the employees who have BLAKE as their manager.
 解析:
利用worker.mgr=manager.empno语句将两表连接,再根据条件进行查询manager.ename = 'BLAKE'
 结果:

  1. SELECT worker.*
  2. FROM EMP worker, EMP manager
  3. WHERE worker.mgr = manager.empno
  4. AND manager.ename = 'BLAKE';

实验结论或体会:

本次实验由于给的时间比较长,所以我一共使用两种方式完成了实验
 在wampserver上完成实验
 使用自己的阿里云弹性云服务器完成实验
由于在服务器上完成实验会更贴近开发中实际使用数据库的环境,于是在实验报告中我呈现的内容为在服务器上完成的

本次实验收获还是很大的,但是也遇到了一些困难
 一开始的服务器配置,mysql的安装废了我不少功夫
 在导入数据上也下了一番功夫,最后是采用的sql语句中的insert方式插入的
 在一开始的1-21题中倒是没有遇到非常难的问题
 在之后的1-6题中,个人感觉某些连接查询的部分还是会费点功夫的
 例如在第二部分的第4题中查询的逻辑就比较复杂
 用到了多级查询,首先利用DEPT.deptno = EMP.deptno语句将emp和dept两表连接,查询出deptno字段作为集合,在集合中利用deptno字段查找出没有任何雇员的部门,

相关文章
|
13天前
|
SQL 存储 关系型数据库
MySQL/SqlServer跨服务器增删改查(CRUD)的一种方法
通过上述方法,MySQL和SQL Server均能够实现跨服务器的增删改查操作。MySQL通过联邦存储引擎提供了直接的跨服务器表访问,而SQL Server通过链接服务器和分布式查询实现了灵活的跨服务器数据操作。这些技术为分布式数据库管理提供了强大的支持,能够满足复杂的数据操作需求。
57 12
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-21 Sqoop 数据迁移工具 简介与环境配置 云服务器 ETL工具 MySQL与Hive数据互相迁移 导入导出
Hadoop-21 Sqoop 数据迁移工具 简介与环境配置 云服务器 ETL工具 MySQL与Hive数据互相迁移 导入导出
114 3
|
4月前
|
存储 关系型数据库 MySQL
使用Docker快速部署Mysql服务器
本文介绍了如何使用Docker快速部署MySQL服务器,包括下载官方MySQL镜像、启动容器、设置密码、连接MySQL服务器以及注意事项。
648 18
|
5月前
|
关系型数据库 MySQL 网络安全
有关使用Navicat 无法成功连接腾讯云服务器上Mysql的问题解决
这篇文章提供了解决Navicat无法连接腾讯云服务器上MySQL问题的步骤,包括调整防火墙设置、更新MySQL权限和检查远程连接配置。
有关使用Navicat 无法成功连接腾讯云服务器上Mysql的问题解决
|
5月前
|
关系型数据库 MySQL Linux
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
|
5月前
|
关系型数据库 MySQL Linux
数据类型和运算符(MySQL服务器的安装,MySQL客户端,数据类型,运算符,MySQL的语法规范)
无论是对于初学者还是有经验的开发者,了解MySQL的安装、客户端使用、数据类型、运算符和语法规范都是至关重要的。这不仅有助于高效地管理和查询数据,而且对于设计和实现数据库解决方案来说是基础工作。通过深入学习和实践这些知识,您可以更好地发挥MySQL数据库的强大功能。
41 2
|
5月前
|
SQL Ubuntu 关系型数据库
如何在云服务器上创建和管理 MySQL 和 MariaDB 数据库
如何在云服务器上创建和管理 MySQL 和 MariaDB 数据库
71 0
|
15天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
40 3
|
15天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
43 3
|
15天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE &#39;log_%&#39;;`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
58 2

推荐镜像

更多