SQL语句的增删改查

SQL语句的增删改查

存在一个关系模式:学生-课程模式S-T
学生表:Student(Sno,Sname,Ssex,Sage,Sdept)
课程表:Course(Cno,Cname,Cpno,Ccredit)
学生选课表:(Sno,Cno,Grade)
(关系的主码斜体表示)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

基本表的定义、删除与修改

建立一个学生表:
Create table Student(
Sno char(9) Primary key,
Sname char(20) unique,
Ssex char(2),
Sage smallint,
Sdept char(20));

建立一个课程表:
create table Course (
Cno char(9) Primary key,
Cname char(20) not null,
Cpno char(9),
Ccredit smallint,
foreign key(Cpno) references Course(Cno));

建立一个学生选课表
create table SC(
Sno char(9),
Cno char(4),
Grade smallint,
primary key(Sno,Cno),
foreign key(Sno) references Student(Sno),
foreign key(Cno) references Course(Cno));

单表查询

1.查询全体学生的姓名及其出生年份
select Sname,2020-Sage from Student;

2.查询全体学生的姓名、出生年份和所在的院系,要求用小写字母表示系名
select Sname,‘Year of Birth’,2020-Sage Birthday,Lower(Sdept) department from Student;

3.查询选修了课程的学生学号(去重)
select distinct Sno from SC;

4.查询年龄不在20~23岁之间的学生姓名、系别和年龄
select Sname,Sdept,Sage from Student where Sage not between 20 and 23;

5.查询既不是计算机科学系、数学系、也不是信息系的学生的姓名和性别
select Sname,Ssex from Student where Sdept not in(‘CS’,‘MA’,'IS);

6.查询所有姓“刘”的学生的所有信息(’%'任意长度)
select * from Student where Sname like ‘刘%’;

7.查询姓“欧阳”且全名为三个汉字的学生的姓名(’_’ 单个字符)
select Sname from Student where Sname like ‘欧阳_’;

8.查询名字中第二个字为“阳”的学生的姓名和学号
select Snam,Sno from Student where Sname like ‘_阳%’;

9.查询选修了3号课程的学生的学号及其成绩,查询结果按分数的降序排列
select Sno,Grade from SC where Cno=‘3’ order by Grade DESC;

聚集函数
COUNT(*)
COUNT([DISTINCT|ALL]<列名>)
SUM([DISTINCT|ALL]<列名>)
AVG([DISTINCT|ALL]<列名>)
MAX([DISTINCT|ALL]<列名>)
MIN([DISTINCT|ALL]<列名>)

10.查询选修了课程的学生人数(去重)
select count(distinct Sno) from SC;

11.求每个课程号及相应的选课人数
select Cno,count(Sno) from SC group by Cno;

12.查询选修了三门以上课程的学生学号
select Sno from SC group by Sno having count(*)>3;

13.查询平均成绩大于等于90分的学生学号和平均成绩
select Sno,AVG(Grade) from SC group by Sno having AVG(Grade)>=90;

连接查询
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle是一种关系型数据库管理系统,支持使用SQL语言进行数据的增删改查操作。 1. 数据的插入(Insert): INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); 2. 数据的查询(Select): SELECT column1, column2, ... FROM table_name WHERE condition; 3. 数据的更新(Update): UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition; 4. 数据的删除(Delete): DELETE FROM table_name WHERE condition; 5. 创建表(Create Table): CREATE TABLE table_name (column1 datatype, column2 datatype, ...); 6. 删除表(Drop Table): DROP TABLE table_name; 7. 修改表(Alter Table): ALTER TABLE table_name ADD column_name datatype; ALTER TABLE table_name DROP COLUMN column_name; ALTER TABLE table_name MODIFY column_name datatype; 8. 创建索引(Create Index): CREATE INDEX index_name ON table_name (column1, column2, ...); 9. 删除索引(Drop Index): DROP INDEX index_name; 10. 创建视图(Create View): CREATE VIEW view_name AS SELECT column1, column2, ... FROM table_name WHERE condition; 11. 删除视图(Drop View): DROP VIEW view_name; 12. 数据的排序(Order By): SELECT column1, column2, ... FROM table_name ORDER BY column_name ASC|DESC; 13. 数据的分组(Group By): SELECT column1, column2, ... FROM table_name GROUP BY column_name; 14. 数据的联接(Join): SELECT column1, column2, ... FROM table1 INNER JOIN table2 ON table1.column_name = table2.column_name; 这些是Oracle中常用的SQL语句,通过这些语句可以完成数据的增删改查及其他相关操作。但需要注意的是,具体的语法和用法可能因为不同的版本和具体的需求而略有区别。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值