Oracle 基础(2)——创建表单

本文介绍了在Oracle中创建表单的基本操作,包括定义不同数据类型如number、varchar2和date,以及如何添加各种约束,如唯一性(Uk)约束、检查(Check)约束和主键(Pk)外键约束。通过示例展示了创建全面关系表的方法,涉及主键、外键和级联修改等概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建表单


oracle中的数据类型

number(n) 数字( 最长n位 )

number(n , m) 浮点数( 总长n为, 小数点后m位 )

char(n)表示定长字符串

varchar(n)表示变长字符串( 节省空间 ) 

varchar2(n)Oracle自己定义的变长字符串

date 日期

 

创建一个简单的数据表

CREATETABLE dept_xxx(

deptnoNUMBER(2) primary key,

dname VARCHAR2(30) not null,//not null设置为非空

//dname VARCHAR2(30) constraint student_name_nn not null,设置别名

dlocationVARCHAR2(30),

);

 

CREATETABLE dept_xxx(

deptnoNUMBER(2),

dnameVARCHAR2(30),

dlocationVARCHAR2(30),

constraintdept_xxx_deptno_pk primary key (deptno));

//设置主键名dept_xxx_deptno_pk 主键为deptno (主键可以设计多行)

 

添加Uk唯一约束

create tableuk_table (

num NUMBER(2),

email varchar2(30)UNIQUE);

create tableuk_table (

num NUMBER(2),

email varchar2(30),

constraintuk_table_email_uk unique(email));

 

 

添加Check约束

create tablecheck_table(

sex char(1),

constraintcheack_table_ck CHECK( sex in('f','m')));

 

添加Pk外键约束


专业表

create table major(

id number(2),

name varchar2(20),

constraintmajor_id_pk primary key(id));

学生表

CREATE tablestudent(

id number (2),

name varchar2(20),

major_id number(2),

constraintstudent_id_pk primary key(id),

constraintmajor_student_majorid_fk foreign key (major_id) references major(id) on delete set null);

设置外键,外键为major_id主键为major的id ,当主键表中删除是,外键表设置为null(级联修改)


创建一个较为全面的关系表(事例)

CREATE TABLE student(

s_numVARCHAR2 (12),

major_numNUMBER (2),

s_nameVARCHAR2 (12),

s_sexCHAR (1),

heightNUMBER (3),

weightNUMBER (3),

birthdayDATE,

native_placeVARCHAR2 (20),

CONSTRAINTstudent_num_pk PRIMARY KEY (s_num),

CONSTRAINT major_student_major_num_fk foreign KEY(major_num) REFERENCEs major(major_num),

CONSTRAINTstudent_check_sex_ck CHECK (LOWER(s_sex) IN('f', 'm')),

CONSTRAINTstudent_check_height_ck CHECK (height > 0),

CONSTRAINTstudent_check_weight_ck CHECK (weight > 0),

CONSTRAINTstudent_check_birthday_ck CHECK (

birthday> "TO_DATE" ('1950-01-01', 'yyyy-MM-dd')

ANDbirthday < "SYSDATE"

)

);

 

CREATE TABLE course(

c_numCHAR (6),

major_numNUMBER (2),

c_nameVARCHAR2 (20),

typeNUMBER (1),

creditNUMBER (2),

CONSTRAINTcourse_num_pk PRIMARY KEY (c_num),

CONSTRAINT major_course_major_num_fk foreign KEY(major_num) REFERENCEs major(major_num),

CONSTRAINTcourse_check_type_ck CHECK ("type" IN(1,2,3)),

CONSTRAINTcourse_check_height_ck CHECK ("credit" > 0 and "credit"<= 0)

);

 

CREATE TABLEcourse_tm (

tm_numCHAR (6),

c_numCHAR (6),

constraintcourse_tm_num_pk primary key (tm_num,c_num),

CONSTRAINTcourse_course_tm_c_num_fk foreign KEY (c_num) REFERENCEs course(c_num),

CONSTRAINTteacher_course_tm_tm_num_fk foreign KEY (tm_num) REFERENCEsteaching_material(tm_num)

);

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值