热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle做学生信息系统的脚本

Oracle做学生信息系统的脚本无要求的约束条件有:主键是学号;入学日期必须大于出生日期;总分必须在0到700之间;学号和姓名不能为空createtablestudent(sidnumbernotnullprimarykey,namenvarchar2(10)notnull,birthdaydate,sdatedate,addres

Oracle做学生信息系统的脚本 无 要求的约束条件有: 主键是学号;入学日期必须大于出生日期;总分必须在0到700之间;学号和姓名不能为空create table student (sid number not null primary key,name nvarchar2(10) not null,birthday date,sdate date,addres

Oracle做学生信息系统的脚本
<无>
    要求的约束条件有:
  主键是学号;入学日期必须大于出生日期;总分必须在0到700之间;学号和姓名不能为空


create table student (
	sid number not null primary key,
	name nvarchar2(10) not null,
	birthday date,
	sdate date,
	address nvarchar2(20),
	mark number,
	constraint ck_sdate check(sdate>birthday),
	constraint ck_mark check(mark>=0 and mark<=700))tablespace users;

 insert into student values(1001,'张三','1-1月-1981','1-1月-1999','上海',600);


  用OEM再创建以上表student2,添加约束,并在数据输入窗口输入以下记录:

  表字段名(英文部分)及部分数据如下:
  sid(学号)name(姓名)birthday(出生日期)sdate(入学日期)address(家庭地址 ) mark(入学总分)
  1001     张三名         1981-1-1           1999-1-1       张三名的家庭地址       600
  1002     李三名         1982-2-2           2000-1-1       李三名的家庭地址       620
  1003     张四名         1983-3-3           2001-1-1       张四名的家庭地址       580
  1004     李四名         1984-4-4           2002-1-1       李四名的家庭地址       592
  计算出学生总数;
	select count(1) as 学生总数 from student;

  查询出姓名中第二个字符为“三”而且不姓张的学生;
	select * from student where name like '_三%' and name not like '张%';


  查询出在1982-1-1和1984-1-1之间出生的学生的姓名;
	select name,birthday from student where birthday between to_date('1982-1-1','yyyy-MM-dd') and to_date('1984-1-1','yyyy-MM-dd');


  查询出年龄最小的学生;
	select * from student where birthday in (select max(birthday) from student);

  查询出在学校待的时间最长的学生;
	select * from student where sdate in (select min(sdate) from student);

  计算出所有学生总分的平均分;
	select avg(mark) as 平均分 from student;

  显示总分最高的学生的总分和姓名;
	select name,mark from student where mark in (select max(mark) from student);

  删除总分在600以下的学生,然后进行回滚;
	delete from student where mark<600 ;rollback;

  为表添加两列,一列是sex(性别),一列是speciality(专业),
  	其中,专业部分的默认值是“外语”;且有一个名为CK_SEX的约束条件:性别只能是“男”或“女;
  修改专业的默认值为“计算机”;
	alter table student add(sex nvarchar2(4) check (sex='男' or sex='女'), speciality nvarchar2(10) default '外语');
	alter table student modify(speciality default '计算机');
id(编号)  sid(学生编号)  testtype(考试类型) score(分数)
   1	    	1001	       期中             580
   2	   	1001	       期末		590
   3	    	1002           期中             570
   4        	1002           期末	        595
   5       	1003           期中	        570
   6        	1003           期末	        565
	
create table score
(
	id number not null,
	sid number not null,
	testtype nvarchar2(10),
	score number	
);
用OEM界面给score创建一个外键,对应student的主键,然后在sql*plus中用sql语句删除此外键,再用sql语句为score创建一个外键;
	alter table score drop constraint SCORE_FK21245050242859;
	alter table score add (constraint fk_sid foreign key(sid) references student(sid));
	select sid,name,address from student  where mark>610 and sid in
		(select sid from score where testtype='期末' and score>=590);
update score set score=score+10 where testtype='期末' and sid in (select sid from student where mark>=600);
select * from student where sid not in (select sid from score);

推荐阅读
  • 本文详细探讨了不同SQL数据库管理系统(DBMS)在限制输出结果、拼接字段和日期时间处理方面的函数差异。通过具体示例,帮助读者理解并掌握如何在不同DBMS中实现相同功能。 ... [详细]
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文详细介绍了HTML中标签的使用方法和作用。通过具体示例,解释了如何利用标签为网页中的缩写和简称提供完整解释,并探讨了其在提高可读性和搜索引擎优化方面的优势。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 使用C#开发SQL Server存储过程的指南
    本文介绍如何利用C#在SQL Server中创建存储过程,涵盖背景、步骤和应用场景,旨在帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文探讨了适用于Spring Boot应用程序的Web版SQL管理工具,这些工具不仅支持H2数据库,还能够处理MySQL和Oracle等主流数据库的表结构修改。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 在使用 DataGridView 时,如果在当前单元格中输入内容但光标未移开,点击保存按钮后,输入的内容可能无法保存。只有当光标离开单元格后,才能成功保存数据。本文将探讨如何通过调用 DataGridView 的内置方法解决此问题。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 如何在PostgreSQL中查看数据表
    本文将指导您使用pgAdmin工具连接到PostgreSQL数据库,并展示如何浏览和查找其中的数据表。通过简单的步骤,您可以轻松访问所需的表结构和数据。 ... [详细]
author-avatar
冰冻的幸福yasminzp_815
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有