数据库系统集合查询训练
查询选修了3号课程但没有选修1号课程的学生
select student.*
from student
where sno in(
select sno
from sc
where cno='3')
except
select student.*
from student
where sno in(
select sno
from sc
where cno='1');
查询既选修了‘数学’又选修了‘信息系统’的学生
select student.*
from student
where sno in(
select sno
from sc
where cno=(
select cno
from course
where cname='数学') )
intersect
select student.*
from student
where sno in(
select sno
from sc
where cno=(
select cno
from course
where cname='信息系统') );
cpu执行一条指令的步骤详细过程
中央处理器(CPU)工作都可以分为5个阶段:取指令、指令译码、执行指令、访存取数、结果写回。
1、取指令阶段,取指令(Instruction Fetch,IF)阶段是将一条指令从主存中取到指令寄存器的过程。
2.指令译码阶段,取出指令后,计算机立即进入指令译码(Instruction Decode,ID)阶段。在指令译码阶段,指令译码器按照预定的指令格式,对取回的指令进行拆分和解释,识别区分出不同的指令类别以及各种获取操作数的方法。
3、执行指令阶段,在取指令和指令译码阶段之后,接着进入执行指令(Execute,EX)阶段。此阶段的任务是完成指令所规定的各种操作,具体实现指令的功能。为此,CPU的不同部分被连接起来,以执行所需的操作。
4、访存取数阶段,根据指令需要,有可能要访问主存,读取操作数,这样就进入了访存取数(Memory,MEM)阶段。此阶段的任务是:根据指令地址码,得到操作数在主存中的地址,并从主存中读取该操作数用于运算。
5、结果写回阶段,结果写回(Writeback,WB)阶段把执行指令阶段的运行结果数据“写回”到某种存储形式:结果数据经常被写到CPU的内部寄存器中,以便被后续的指令快速地存取。在指令执行完毕、结果数据写回之后,若无意外事件(如结果溢出等)发生,计算机就接着从程序计数器PC中取得下一条指令地址,开始新一轮的循环,下一个指令周期将顺序取出下一条指令。