首页 > 数据库 >Mysql练习

Mysql练习

时间:2023-05-27 13:01:49浏览次数:44  
标签:sal -- 练习 员工 emp Mysql WHERE SELECT

1. 练习1

1.1 选择题   811

Mysql练习_ci

代码在E:\java学习\初级\course166\db_

exercise01
-- 选择题写法对错判断  811
-- 错误,as可以省略但是Annual Salary中间有空格会被认为Salary是最终的别名
SELECT ename,sal*12 AS Annual Salary FROM emp
SELECT ename,sal*12 AS "Annual Salary" FROM emp-- 正确
SELECT empno,ename `name`,sal salary FROM emp-- as可以省略

2. 练习2  812

写出查看DEPT表和EMP表的结构的sq|语句

代码在E:\java学习\初级\course166\db_

exercise02

-- 写出查看DEPT表和EMP表的结构的sq|语句   812
DESC dept
DESC emp

3. 练习3    812

 使用简单查询语句完成 

(1) 显示所有部门名称。

(2) 显示所有雇员名及其全年收入 13月(工资+补助),并指定列别名”年收入"

代码在E:\java学习\初级\course166\db_

exercise02

--  使用简单查询语句完成   812
-- (1) 显示所有部门名称。
SELECT dname
	FROM dept
-- (2) 显示所有雇员名及其全年收入 13月(工资+补助),并指定列别名”年收入"
SELECT ename,(sal+IFNULL(comm,0))*13 AS '年收入'
	 FROM emp#IFNULL(comm,0)函数的意思是,如果comm不为空就显示本身,如果为空就显示为0
	 
SELECT 700+NULL FROM DUAL-- 提示任何数和null相加都得null

4. 练习4  812

限制查询数据。

(1)显示工资超过2850的雇员姓名和工资。

(2) 显示工资不在1500到2850之间的所有雇员名及工资。

(3)显示编号为7566的雇员姓名及所在部门编号。

(4) 显示部门10和30中工资超过1 500的雇员名及工资。

(5) 显示无管理者的雇员名及岗位。

代码在E:\java学习\初级\course166\db_

exercise02

-- 限制查询数据。
-- (1)显示工资超过2850的雇员姓名和工资。
SELECT ename,sal
	FROM emp
	WHERE sal>2850
-- (2) 显示工资不在1500到2850之间的所有雇员名及工资。
SELECT ename,sal
	FROM emp
	WHERE sal<1500 OR sal>2850
-- 写法二
SELECT ename,sal
	FROM emp
	WHERE NOT(sal>=1500 AND sal<=2850)
-- (3)显示编号为7566的雇员姓名及所在部门编号。
SELECT ename,deptno
	FROM emp
	WHERE empno=7566

-- (4) 显示部门10和30中工资超过1500的雇员名及工资。
SELECT ename,sal
	FROM emp
	WHERE (deptno=10 OR deptno = 30) AND sal > 1500
-- (5) 显示无管理者的雇员名及岗位。
SELECT ename,job
	FROM emp
	WHERE mgr IS NULL

5. 练习5  812

排序数据。

(1)显示在1991年2月1日到1991年5月1日之间雇用的雇员名,岗位及雇佣日期,并以雇佣日期进行排序。

(2)显示获得补助的所有雇员名.工资及补助,并以工资降序排序

代码在E:\java学习\初级\course166\db_

exercise02

-- 排序数据。   812
-- (1)显示在1991年2月1日到1991年5月1日之间雇用的雇员名,岗位及雇佣日期,并以雇佣日期进行排序。
SELECT ename,job,hiredate
	FROM emp
	WHERE hiredate>='1991-02-01' AND hiredate<='1991-05-01'
	ORDER BY hiredate
-- (2)显示获得补助的所有雇员名.工资及补助,并以工资降序排序
SELECT ename,sal,comm
	FROM emp
	WHERE comm IS NOT NULL
	ORDER BY sal DESC

6. 练习6  813

根据: emp员工表写出正确SQL    813

1.选择部门30中的所有员工

2.列出所有办事员(CLERK)的姓名, 编号和部门编号.

3.找出佣金高于薪金的员工.

4.找出佣金高于薪金60%的员工.

5.找出部门10中所有经理(MANAGER)和部门20中所有办事员(CLERK)的详细资料.

6.找出部门10中所有经理(MANAGER),部]20中所有办事员(CLERK),还有既不是经理又不是办事员,但其薪金大于或等于2000的所有员工的详细资料.

7.找出收取佣金的员工的不同工作.

8.找出不收取佣金或收取的佣金低于100的员工.

9.找出各月倒数第3天受雇的所有员工.

10.找出早于12年前受雇的员工.

11.以首字母小写的方式显示所有员工的姓名.

12.显示正好为5个字符的员工的姓名.

代码在E:\java学习\初级\course166\db_

exercise03

-- 根据: emp员工表写出正确SQL   813
-- 1.选择部门30中的所有员工
SELECT *
	FROM emp
	WHERE deptno=30
-- 2.列出所有办事员(CLERK)的姓名, 编号和部门编号.
SELECT ename,empno,deptno
	FROM emp
	WHERE job='CLERK'
-- 3.找出佣金(奖金)高于薪金的员工.
SELECT *
	FROM emp
	WHERE IFNULL(comm,0)>sal
-- 4.找出佣金高于薪金60%的员工.
SELECT *
	FROM emp
	WHERE IFNULL(comm,0)>sal*0.6
-- 5.找出部门10中所有经理(MANAGER)和部门20中所有办事员(CLERK)的详细资料.
SELECT *
	FROM emp
	WHERE (deptno=10 AND job='MANAGER') 
	OR (deptno=20 AND job='CLERK')
-- 6.找出部门10中所有经理(MANAGER),部]20中所有办事员(CLERK),还有既不是经理
-- 又不是办事员,但其薪金大于或等于2000的所有员工的详细资料.
SELECT *
	FROM emp
	WHERE (deptno=10 AND job='MANAGER') 
	OR (deptno=20 AND job='CLERK')
	OR(job !='MANAGER' AND job!='CLERK' AND sal>=2000)
-- 7.找出收取佣金的员工的不同工作.
SELECT DISTINCT job
	FROM emp
	WHERE comm IS NOT NULL
-- 8.找出不收取佣金或收取的佣金低于100的员工.
SELECT *
	FROM emp
	WHERE comm IS NULL OR IFNULL(comm,0)<100
-- 9.找出各月倒数第3天受雇的所有员工.
-- 提示一个函数 last_day(),可以查询到你写的日期这个月的最后一天
-- ,last_day()-2得到日期这个月的倒数第三天
SELECT LAST_DAY(NOW())

SELECT *
	FROM emp
	WHERE LAST_DAY(hiredate)-2 = hiredate

-- 10.找出早于12年前受雇的员工.(即入职时间超过12年的)
#他入职的时间加上12年还没到现在的时间(
SELECT * 
	FROM emp
	WHERE DATE_ADD(hiredate,INTERVAL 12 YEAR) < NOW()
-- 11.以首字母小写的方式显示所有员工的姓名.
SELECT CONCAT(LCASE(SUBSTRING(ename,1,1)),SUBSTRING(ename,2))#SUBSTRING(ename,2)后面不写取几个,就代表后面全部取出来了
	FROM emp
-- 12.显示正好为5个字符的员工的姓名.
SELECT *
	FROM emp
	WHERE LENGTH(ename)

7. 练习7  814

根据:emp员工表写出正确SQL 

13.显示不带有" R"的员工的姓名.

14.显示所有员工姓名的前三个字符.

15.显示所有员工的姓名,用a替换所有"A"

16.显示满10年服务年限的员工的姓名和受雇日期.

17.显示员工的详细资料,按姓名排序.

18.显示员工的姓名和受雇日期,根据其服务年限,将最老的员工排在最前面.

19.显示所有员工的姓名、工作和薪金按工作降序排序,若工作相同则按薪金排序

20.显示所有员工的姓名、 加入公司的年份和月份按受雇日期所在月排序,若月份相同则将最早年份的员工排在最前面.

21.显示在一个月为30天的情况所有员工的日薪金 忽略余数.

22.找出在(任何年份的)2月受聘的所有员工。

23.对于每个员工,显示其加入公司的天数.

24.显示姓名字段的任何位置包含 ”A"的所有员 工的姓名.

25.以年月日的方式显示所有员工的服务年限,(大概)

代码在E:\java学习\初级\course166\db_

exercise04

-- 根据:emp员工表写出正确SQL    814
-- 13.显示不带有" R"的员工的姓名.
SELECT * 
	FROM emp
	WHERE ename NOT LIKE '%R%'
-- 14.显示所有员工姓名的前三个字符.
SELECT LEFT(ename,3)
	FROM emp
-- 15.显示所有员工的姓名,用a替换所有"A"
SELECT REPLACE(ename,'A','a') 
	FROM emp
-- 16.显示满10年服务年限的员工的姓名和受雇日期.
SELECT ename,hiredate
	FROM emp
	WHERE DATE_ADD(hiredate,INTERVAL 10 YEAR)<=NOW()
-- 17.显示员工的详细资料,按姓名排序.
SELECT * 
	FROM emp
	ORDER BY ename
-- 18.显示员工的姓名和受雇日期,根据其服务年限,将最老的员工排在最前面.
SELECT ename,hiredate
	FROM emp
	ORDER BY hiredate
-- 19.显示所有员工的姓名、工作和薪金按工作降序排序,若工作相同则按薪金排序
SELECT ename,job,sal
	FROM emp
	ORDER BY job DESC ,sal
-- 20.显示所有员工的姓名、 加入公司的年份和月份按受雇日期所在月排序,
-- 若月份相同则将最早年份的员工排在最前面.
SELECT ename,CONCAT(YEAR(hiredate),'-',MONTH(hiredate))
	FROM emp
	ORDER BY MONTH(hiredate),YEAR(hiredate)
	
-- 21.显示在一个月为30天的情况所有员工的日薪金 忽略余数.
SELECT ename,FLOOR(sal/30),sal/30#FLOOR不带四舍五入,round可以
	FROM emp
-- 22.找出在(任何年份的)2月受聘的所有员工。
SELECT *
	FROM emp
	WHERE MONTH(hiredate)=2
-- 23.对于每个员工,显示其加入公司的天数.
SELECT ename,DATEDIFF(NOW(),hiredate)
	FROM emp
-- 24.显示姓名字段的任何位置包含 ”A"的所有员 工的姓名.
SELECT *
	FROM emp
	WHERE ename LIKE '%A%'
-- 25.以年月日的方式显示所有员工的服务年限,(大概)
SELECT ename,FLOOR(DATEDIFF(NOW(),hiredate) / 365) AS " 工作年",
	FLOOR((DATEDIFF(NOW(),hiredate) % 365) / 31) AS " 工作月",
	DATEDIFF(NOW(),hiredate) % 31 AS " 工作日"
	FROM emp

8. 练习8   815-816

根据: emp员工表, dept部门表,工资=薪金sal +佣金comm写出正确SQL 

(1).列出至少有一个员工的所有部门

(2).列出薪金比"SMITH"多的所有员工。

(3).列出受雇日期晚于其直接上级的所有员工。

(4).列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。

(5).列出所有"CLERK”(办事员) 的姓名及其部门名称。

(6).列出最低薪金大于1 500的各种工作。

(7).列出在部门"SALES" (销售部) 工作的员工的姓名。

(8).列出薪金高于公司平均薪金的所有员工。

代码在E:\java学习\初级\course167\db_

exercise05

-- 根据: emp员工表, dept部门表,工资=薪金sal +佣金comm写出正确SQL   815
-- (1).列出至少有一个员工的所有部门
-- 思路:先查出各个部门有多少人,在使用having子句过滤
SELECT COUNT(*) AS c,deptno
	FROM emp
	GROUP BY deptno
	HAVING c>1
-- (2).列出薪金比"SMITH"多的所有员工。
-- 思路先查询Smith的工资,然后把他当作一个子查询
SELECT sal 
	FROM emp
	WHERE ename='SMITH'#查询出Smith的工资
SELECT ename ,sal
	FROM emp
	WHERE sal>(SELECT sal 
			FROM emp
			WHERE ename='SMITH')
-- (3).列出受雇日期晚于其直接上级的所有员工。
/*
	先把 emp 表 当做两张表 worker , leader
	条件 1. worker.hiredate > leader.hiredate
	     2. worker.mgr = leader.empno
*/
SELECT worker.ename AS '员工名',worker.hiredate AS '员工入职时间',
	leader.ename AS '上级名',leader.hiredate AS '上级入职时间'
	FROM emp AS worker,emp AS leader
	WHERE worker.hiredate>leader.hiredate 
	AND worker.mgr=leader.empno#工人的上级编号=上级的员工编号,说明我的上级就是你

-- (4).列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
/*
	这里因为需要显示所有部门,因此考虑使用外连接,(左外连接)
	如果没有印象了,去看看外连接.
*/
SELECT dname,emp.*
	FROM dept LEFT JOIN emp 
	ON dept.deptno=emp.deptno

-- (5).列出所有"CLERK”(办事员) 的姓名及其部门名称。
SELECT ename,dname,job
	FROM emp,dept
	WHERE job = 'CLERK' AND emp.deptno = dept.deptno
-- (6).列出最低薪金大于1500的各种工作。
/*
	查询各个部门的最低工资
	使用having 子句进行过滤
*/

SELECT MIN(sal) AS min_sal,job
	FROM emp
	GROUP BY job
	HAVING min_sal>1500
-- (7).列出在部门"SALES" (销售部) 工作的员工的姓名。  816
SELECT ename,dname
	FROM emp,dept
	WHERE emp.deptno=dept.deptno AND dname='SALES'
-- (8).列出薪金高于公司平均薪金的所有员工。

SELECT *
	FROM emp
	WHERE sal>(
		SELECT AVG(sal) AS avg_sal
			FROM emp)

9. 练习8    816

根据:emp员工表, dept部门表,工资=薪金+佣金写出正确SQL 

(9).列出与"SCOTT"从事相同工作的所有员工。

(10).列出薪金高于所在部门30工作的所有员工的薪金的员工姓名和薪金。

(11).列出在每个部门工作的员工数量、平均工资和平均服务期限。

(12).列出所有员工的姓名、部门名称和工资。

(13).列出所有部门的详细信息和部门人数。

(14).列出各种工作的最低工资。

(15).列出MANAGER (经理)的最低薪金。

(16).列出所有员工的年工资,按年薪从低到高排序。

代码在E:\java学习\初级\course167\db_

exercise06

-- 根据:emp员工表, dept部门表,工资=薪金+佣金写出正确SQL    816
-- (9).列出与"SCOTT"从事相同工作的所有员工。
SELECT *
	FROM emp
	WHERE job=(
		SELECT job
		FROM emp
		WHERE ename = 'SCOTT')
-- (10).列出薪金高于所在部门30工作的所有员工的薪金的员工姓名和薪金。
-- 先查询出30部门的最高工资
SELECT MAX(sal)
	FROM emp
	WHERE deptno=30
SELECT ename,sal
	FROM emp
	WHERE sal>(
		SELECT MAX(sal)
		FROM emp
		WHERE deptno=30)
-- (11).列出在每个部门工作的员工数量、平均工资和平均服务期限。
-- 提示format()函数可以保留小数位
SELECT COUNT(*) AS "部门员工数量",deptno,AVG(sal) AS "部门平均工资",
	AVG(DATEDIFF(NOW(),hiredate)/365) AS "平均服务期限(年)"
	FROM emp
	GROUP BY deptno
-- (12).列出所有员工的姓名、部门名称和工资。
SELECT ename,dname,sal
	FROM emp,dept
	WHERE emp.deptno = dept.deptno
-- (13).列出所有部门的详细信息和部门人数。
-- 1. 先得到各个部门人数 , 把下面的结果看成临时表 和 dept表联合查询
SELECT COUNT(*) AS c,deptno
	FROM emp
	GROUP BY deptno
-- 2.
SELECT dept.*,tmp.c AS '部门人数'
	FROM dept,(
		SELECT COUNT(*) AS c,deptno
		FROM emp
		GROUP BY deptno) tmp
	WHERE tmp.deptno=dept.deptno
-- (14).列出各种工作的最低工资。
SELECT MIN(sal),job
	FROM emp
	GROUP BY job

-- (15).列出MANAGER (经理)的最低薪金。
SELECT MIN(sal),job
	FROM emp
	WHERE job = 'MANAGER'
-- (16).列出所有员工的年工资,按年薪从低到高排序。
-- 先得到员工的年工资
SELECT ename,(sal+IFNULL(comm,0))*12 AS year_sal
	FROM emp
	ORDER BY year_sal

10. 练习9  817

设学校环境如下:一个系有若千个专业,每个专业一年只招一 个班,每个班有若干个学生。

现要建立关于系、学生、班级的数据库,关系模式为:

班 CLASS (班号classid, 专业名subject, 系名deptname, 入学年份enrolltime, 人数num)

学生 STUDENT (学号studentid, 姓名name,年龄age,班号classid)

系 DEPARTMENT (系号departmentid, 系名deptname)

试用SQL语言完成以下功能: 

(1)建表,在定义中要求声明:

(1)每个表的主外码。

(2) deptname是唯一 约束。

(3)学生姓名不能为空。

(2)插入如下数据

DEPARTMENT ( 001, 数学

002, 计算机;

003, 化学;

004, 中文;

005, 经济; )

(3) 完成以下查询功能

3.1找出所有姓李的学生。

3.2列出所有开设超过1个专业的系的名字。

3.3列出人数大于等于30的系的编号和名字。

(4) 学校又新增加了一 一个物理系,编号为006

(5) 学生张三退学, 请更新相关的表

Mysql练习_SQL_02


Mysql练习_ci_03

代码在E:\java学习\初级\course167\db_

exercise07

-- 设学校环境如下:一个系有若千个专业,每个专业一年只招一 个班,每个班有若干个学生。  817
-- 现要建立关于系、学生、班级的数据库,关系模式为:
-- 班 CLASS (班号classid, 专业名subject, 系名deptname, 入学年份enrolltime, 人数num)
-- 学生 STUDENT (学号studentid, 姓名name,年龄age,班号classid)
-- 系 DEPARTMENT (系号departmentid, 系名deptname)
-- 试用SQL语言完成以下功能: 

-- (1)建表,在定义中要求声明:
-- (1)每个表的主外码。
-- (2) deptname是唯一 约束。
-- (3)学生姓名不能为空。

-- 创建表 系 DEPARTMENT (系号departmentid, 系名deptname)
CREATE TABLE DEPARTMENT(
	departmentid VARCHAR(32) PRIMARY KEY,
	deptname VARCHAR(32) UNIQUE NOT NULL);
	
-- 班 CLASS (班号classid, 专业名subject, 系名deptname, 入学年份enrolltime, 人数num)
CREATE TABLE `class`(
	classid INT PRIMARY KEY,
	`subject` VARCHAR(32) NOT NULL DEFAULT '',
	deptname VARCHAR(32),-- 外键字段,在后面定义
	enrolltime INT NOT NULL DEFAULT 2000,
	num INT NOT NULL DEFAULT 2000,
	FOREIGN KEY(deptname) REFERENCES DEPARTMENT(deptname));
-- 学生 STUDENT (学号studentid, 姓名name,年龄age,班号classid)
CREATE TABLE hsp_student(
	studentid INT PRIMARY KEY,
	`name` VARCHAR(32) NOT NULL DEFAULT '',
	age INT NOT NULL DEFAULT 0,
	classid INT,-- 外键
	FOREIGN KEY(classid) REFERENCES `class`(classid));

-- 添加测试数据

INSERT INTO department VALUES('001','数学');
INSERT INTO department VALUES('002','计算机');
INSERT INTO department VALUES('003','化学');
INSERT INTO department VALUES('004','中文');
INSERT INTO department VALUES('005','经济');

INSERT INTO class VALUES(101,'软件','计算机',1995,20);
INSERT INTO class VALUES(102,'微电子','计算机',1996,30);
INSERT INTO class VALUES(111,'无机化学','化学',1995,29);
INSERT INTO class VALUES(112,'高分子化学','化学',1996,25);
INSERT INTO class VALUES(121,'统计数学','数学',1995,20);
INSERT INTO class VALUES(131,'现代语言','中文',1996,20);
INSERT INTO class VALUES(141,'国际贸易','经济',1997,30);
INSERT INTO class VALUES(142,'国际金融','经济',1996,14);

INSERT INTO hsp_student VALUES(8101,'张三',18,101);
INSERT INTO hsp_student VALUES(8102,'钱四',16,121);
INSERT INTO hsp_student VALUES(8103,'王玲',17,131);
INSERT INTO hsp_student VALUES(8105,'李飞',19,102);
INSERT INTO hsp_student VALUES(8109,'赵四',18,141);
INSERT INTO hsp_student VALUES(8110,'李可',20,142);
INSERT INTO hsp_student VALUES(8201,'张飞',18,111);
INSERT INTO hsp_student VALUES(8302,'周瑜',16,112);
INSERT INTO hsp_student VALUES(8203,'王亮',17,111);
INSERT INTO hsp_student VALUES(8305,'董庆',19,102);
INSERT INTO hsp_student VALUES(8409,'赵龙',18,101);

SELECT * FROM department
SELECT * FROM class
SELECT * FROM hsp_student

-- (3) 完成以下查询功能
-- 3.1找出所有姓李的学生。
SELECT * 
	FROM hsp_student
	WHERE `name` LIKE '李%'
	
-- 3.2列出所有开设超过1个专业的系的名字。
-- 1. 先查询各个系有多少个专业
SELECT COUNT(*) AS nums,deptname
	FROM class
	GROUP BY deptname HAVING nums>1
-- 3.3列出人数大于等于30的系的编号和名字。
-- 1. 先查出各个系有多少人, 并得到 >= 30 的系
SELECT SUM(num) AS nums ,deptname
	FROM class
	GROUP BY deptname
	HAVING nums >= 30
-- 2. 将上面的结果看成一个临时表 和 department 联合查询即可
SELECT tmp.*,department.departmentid
	FROM department,(
		SELECT SUM(num) AS nums ,deptname
			FROM class
			GROUP BY deptname
			HAVING nums >= 30
		)tmp
	WHERE department.deptname = tmp.deptname;
	
-- (4) 学校又新增加了一 一个物理系,编号为006
-- 添加一条数据
INSERT INTO department VALUES('006','物理系')
-- (5) 学生张三退学, 请更新相关的表
-- 分析:1. 张三所在班级的人数-1 2. 将张三从学生表删除  3. 需要使用事务控制

-- 先查一下
SELECT * FROM hsp_student
SELECT * FROM class
-- 开启事务
START TRANSACTION
-- 张三所在的班级人数-1
UPDATE class SET num = num-1
	WHERE classid=(
		SELECT classid
			FROM hsp_student
			WHERE `name`='张三'
	)
-- 删除张三
DELETE 
	FROM hsp_student
	WHERE `name`='张三'
-- 提交事务
COMMIT
-- 再先查一下
SELECT * FROM hsp_student
SELECT * FROM class


标签:sal,--,练习,员工,emp,Mysql,WHERE,SELECT
From: https://blog.51cto.com/u_15784725/6362007

相关文章

  • MySQL学习进阶篇Day2
    2.索引2.1索引概述2.1.1介绍索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。 一提到数据结构,大......
  • MySQL数据类型
    数据类型的选取原则:更小的通常更好:尽量使用可以正确存储数据的最小数据类型(它们占用更少的磁盘,内存,cpu缓存,处理时需要的cpu周期也更少)简单:简单数据类型的操作通常所需cpu周期更少,例如整型就是比字符串类型的操作代价更低尽量避免NULL:最好指定列为NOTNULL,如果......
  • ubuntu 20.4 安装msyql+创建mysql用户
    sudoapt-getupdatesudoapt-getupgratesudoaptinstallmysql-server设置运行远程访问修改:sudovim/etc/mysql/mysql.conf.d/mysqld.cnf用#注释掉bind-address=127.0.0.1进入mysql创建用户mysql-uroot-pCREATEUSER'test'@'%'IDENTIFIEDBY'12345......
  • MySQL的间隙锁
    什么是间隙锁?间隙锁就是在MySQL的一个范围锁,对某个不存在数据的范围进行加锁,加锁后,不能在这个范围内插入数据;在可重复读事务隔离级别下,默认使用的是next-keyLock(行锁+间隙锁);间隙锁是为了解决什么问题?间隙锁就是MySQL在Innodb存储引擎在可重复读的事务隔离级别下为了解决当前读......
  • MySQL刷题记录
    1. select*fromemployeesorderbyhire_datedesclimit1; 笔记: limit 0,1;使用limit关键字从第0条记录向后读取一个,也就是第一条记录  2.select*fromtestLIMIT 3OFFSET 1;(在mysql 5以后支持这种写法)当limit和offset组合使用的时候,limit后面只......
  • rhel 7.3搭建mysql的主从复制—非单机场景
    文档课题:rhel7.3搭建mysql的主从复制—非单机场景.数据库:mysql8.0.27系统:rhel7.3安装包:mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz环境介绍:1、理论知识master将操作语句记录到binlog日志,然后授予slave远程连接权限(master需开启binlog,为数据安全考虑,slave也开启binlog).s......
  • mysql在执行start slave命令时报错"ERROR 1872 (HY000)"
    问题描述:mysql在执行startslave命令时报错"ERROR1872(HY000)",如下所示:数据库:mysql8.0.27系统:rhel7.31、问题重现mysql>startslave;ERROR1872(HY000):Slavefailedtoinitializerelayloginfostructurefromtherepository2、异常原因从库已经存在之前的relay......
  • c++打卡练习(40)(大一最后一次)
    求可逆素数若一个四位数的素数把它倒序过来还是素数,那么称它为可逆素数,如1009和9001就是一对可逆素数流程图:伪代码:源代码:#include<iostream>usingnamespacestd;intmain(){ intstart,end,i,j,m=0; for(i=1000;i<=9999;i++){ intk=0; for(j=2;j<i;j++){ if(i%j==0){ ......
  • rhel 7.3安装mysql 8.0.27
    文档课题:rhel7.3安装mysql8.0.27.系统:rhel7.364位数据库:mysql8.0.27安装包:mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz1、安装前检查1.1、系统版本[root@leo-mysql-master~]#cat/etc/*releaseNAME="RedHatEnterpriseLinuxServer"VERSION="7.3(Maipo)"ID=......
  • 阿里云服务器Linux MySQL root 密码忘记了如何操作?
    阿里云服务器Linux MySQL root密码忘记了如何操作?假如我们使用的MySQL数据库忘记的账号密码,是能够土工调节配置文件,然后跳过密码方式登录到数据库的。然后在数据库里面修改账号和密码,通常在默认情况下账号为root具体操作步骤如下:1】编辑MySQL配置文件my.cnf【注】在具体的操作......