1:用户和权限

1.1 用户的创建

a)语法---    create user 用户名  identified by 密码;

b)创建用户abcd,并设定密码为abcd;---注意:操作数据库对象是需要DBA(数据库管理员)权限的;

create user abcd identified by bjsxt;

1.2 给用户授权

Oracle中的权限很多,为了方便用户管理权限,提供了角色这个概念。角色代表一个身份,该身份拥有固定的权限。常见的角色:DBA(数据库管理员),CONNECT(临时用户,拥有少量的权限),RESOURCE(比较靠谱的权限,拥有更多的权限,不能管理数据库);

a)给abcd用户授予普通用户的权限

grant connect,resource to abcd;

b)从abcd用户撤销resource权限

revoke resource from abcd;

1.3 删除用户

drop user abcd;

1.4修改用户

1.4.1修改用户密码

alter user abcd identified by 123;

1.4.2锁定用户和解锁用户

a)锁定用户

alter user abcd account lock;

b)解锁用户

alter user abcd account unlock;

2.数据库表

2.1Oracle中的数据类型

2.1.1字符类型

a)varchar2---可变长度的字符串

b)cahr       ---不可变长度的字符串,效率较高;

2.1.2数值类型

number,既可以表示整数,也可以表示浮点数;

2.1.3日期时间类型

a)date,存放日期和时间;

b)timestamp,比date更精确的日期时间类型;

2.1.4  lob类型

a)blob,用于存放二进制数据,可以用于存放文件、图片、音频、视频等二进制数据;

b)clob,用于存放答文本信息;

2.2创建表格

创建学生表,字段包含学号、姓名、性别、年龄、入学日期、班级、email等信息;

create table student(

sno number(4),

sname varchar(12),

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50)

)

2.3修改表格

2.3.1添加字段

alter table student add(score number(3));

2.3.2修改字段的类型

alter table student modify(score number(5,2));

2.3.3重命名字段

alter table student rename column score to fenshu ;

2.3.4删除字段

alter table student drop column fenshu;

2.3.5删除表格

drop table stu;

3.表格的约束

constraints,约束,用于对表格的额数据进行限制,保证表格数据的完整性和一致性。

语法:constraints 约束名+约束类型(约束字段)

3.1主键约束(primary key)

主键约束用于唯一标识一条记录的字段,必须保证即非空有唯一。

一张表中,只能有一个主键;

a)在表级别定义主键约束,对约束统一管理

create table student (

sno number(4),

sname varchar2(12),

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50),

constraints pk_student primary key (sno)

);

b)在列级别添加主键约束

create table student (

sno number(4) constraints pk_student primary key,

sname varchar2(12),

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50)

);

c)在列级别添加简化版约束

create table student (

sno number(4) primary key,

sname varchar2(12),

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50)

);

d)联合主键,只能在表级别定义,因为一个表只能有一个主键

create table student (

sno number(4),

sname varchar2(12),

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50),

constraints pk_student primary key (sno, email)

);

3.2非空约束not null

字段值不允许为空,非空约束只能在列级别定义

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50),

constraints pk_student primary key (sno)

);

3.3唯一约束 (unique)

要求字段值不能重复;

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50), -- unique,

constraints pk_student primary key (sno),

constraints uk_student_email unique (email)

);

3.4 检查约束(check)

用于限定字段值的取值范围;

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3) check (gender in ('男', '女')),

age number(3),

sdate date,

clazz varchar2(20),

email varchar2(50),

constraints pk_student primary key (sno),

constraints uk_student_email unique (email),

constraints ck_student_age check (age between 18 and 30)

);

3.5外键约束(foreign key)

用于约束表和表之间的关系,两张标的依赖关系,以emp表和dept表为例,emp表依赖dept表,因此,dept表可以被称之为主表,emp表被称之为从表。

注意:

》主表中,只有主键或唯一建才可以被从表参考;

》从表中作为外键的列,类型一定要和主表的被参考列相同;

a)建立主表clazz

create table clazz (

cno number(3) primary key,

cname varchar2(20) not null,

croom number(3)

);

b)建立从表,并定义外键Student

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3) default '男' check (gender in ('男', '女')),

age number(3),

sdate date,

email varchar2(50),

cno number(3),

constraints pk_student primary key (sno),

constraints uk_student_email unique (email),

constraints ck_student_age check (age between 18 and 30),

constraints fk_student_cno foreign key (cno) references clazz (cno)

);

c)也可以在列级别定义外键,如下

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3) default '男' check (gender in ('男', '女')),

age number(3),

sdate date,

email varchar2(50),

cno number(3) references clazz(cno),

constraints pk_student primary key (sno),

constraints uk_student_email unique (email),

constraints ck_student_age check (age between 18 and 30)

);

d)外键中的删除问题;

》主表中的数据在被引用时,无法直接删除,默认情况下,需要先删除主表中的数据。

》可以在定义外建时,设置删除策略为cascade(级联),表示当删除主表的信息时,同时删除从表中的所有关联的信息

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3) default '男' check (gender in ('男', '女')),

age number(3),

sdate date,

email varchar2(50),

cno number(3),

constraints pk_student primary key (sno),

constraints uk_student_email unique (email),

constraints ck_student_age check (age between 18 and 30),

constraints fk_student_cno foreign key (cno) references clazz (cno) on delete cascade

);

》可以在定义外建时,设置删除策略为set null(设空),表示当删除主表的信息时,将从表中的相关数据设置为null

create table student (

sno number(4),

sname varchar2(12) not null,

gender char(3) default '男' check (gender in ('男', '女')),

age number(3),

sdate date,

email varchar2(50),

cno number(3),

constraints pk_student primary key (sno),

constraints uk_student_email unique (email),

constraints ck_student_age check (age between 18 and 30),

constraints fk_student_cno foreign key (cno) references clazz (cno) on delete set null

);

3.6在修改表格时添加约束

a)给student表添加约束

-- 主键约束

alter table student add constraints pk_student primary key (sno);

-- 唯一约束

alter table student add constraints uk_student_email unique (email);

-- 检查约束

alter table student add constraints ck_student_age check (age between 18 and 30);

alter table student add constraints ck_student_gender check (gender in ('男','女'));

-- 外键约束

alter table student add constraints fk_student_cno foreign key (cno) references clazz (cno);

Oracle常用数据库对象(片段)的更多相关文章

  1. ORACLE常用数据库字段类型

    ORACLE常用数据库字段类型   常用的数据库字段类型如下:   字段类型 中文说明 限制条件 其它说明  CHAR 固定长度字符串 最大长度2000 bytes     VARCHAR2 可变长度 ...

  2. ORACLE常用数据库类型(转)

    oracle常用数据类型 1.Char 定长格式字符串,在数据库中存储时不足位数填补空格,它的声明方式如下CHAR(L),L为字符串长度,缺省为1,作为变量最大32767个字符,作为数据存储在ORAC ...

  3. oracle 备份数据库对象(存储过程PROCEDURE,FUNCTION,VIEW,TRIGGER...)

    开发过程中,需要不停的备份数据库对象, 特别是存储过程, 每次手动备份不免很低能啊 历经几次修改终于, 完美了,O(∩_∩)O哈哈~      (当然,你也可以再改简便一点~~~) select db ...

  4. oracle(创建数据库对象)

    1 --创建数据库 2 --1.SYSDBA系统权限 3 startup:--启动数据库. 4 shutdown:--关闭数据库. 5 alter database[mount]|[open]|[ba ...

  5. MySQL基本命令和常用数据库对象

    MySQL基本命令: 连接远程主机的MySQL服务(为了保证安全性,执行下面命令时,可以省略-p后面的密码,执行命令后系统会提示输入密码) mysql -p 密码 -u 用户名 -h 主机地址 --d ...

  6. Oracle常用数据库表操作

    配置数据库: user:orcl.passward:71911.Hao全局数据库名:orcl..解锁数据库用户名,SCOTT,SYSTEM,SYS,   PWD:71911.Hao输入sqlplus, ...

  7. oracle(查询数据库对象1)

    1 --查询表信息 2 xxx_tables--包含表的基本描述信息和统计信息 3 xxx_tab_columns--包含表中列的描述信息和统计信息 4 xxx_all_tables--包含当前数据库 ...

  8. 【Java EE 学习 28 上】【oracle学习第二天】【子查询】【集合运算】【几种数据库对象】

    一.子查询 1.为什么要使用子查询:问题不能一步求解或者一个查询不能通过一步查询得到. 2.分类:单行子查询和多行子查询. 3.子查询的本质:一个查询中包含了另外一个或者多个查询. 4.使用子查询的规 ...

  9. Oracle 数据库对象

    数据库对象是数据库的组成部分,常常用CREATE命令进行创建,可以使用ALTER命令修改,用DROP执行删除操作.前面已经接触过的数据库对象有表.用户等. 今天将学习更多的Oracle数据库对象: 同 ...

随机推荐

  1. Android存储之SharedPreferences

    Android数据存储之SharedPreferences SharedPreferences对象初始化 SharedPreferences mSharedPreferences = getShare ...

  2. 11 ContextMenu 上下文菜单按钮

    ContextMenu 上下文菜单 在res下的menu里写菜单项 在逻辑代码中 写OnCreateContextMenu() 方法 将菜单项添加到菜单 对菜单项进行监听 onContextItemS ...

  3. 后端分布式系列:分布式存储-HDFS 异常处理与恢复

    在前面的文章 <HDFS DataNode 设计实现解析>中我们对文件操作进行了描述,但并未展开讲述其中涉及的异常错误处理与恢复机制.本文将深入探讨 HDFS 文件操作涉及的错误处理与恢复 ...

  4. studio安装插件

    Android Studio安装插件的方式其实和Eclipse大同小异.废话不多说,直接上图: 区域1:你当前已经安装了的插件 区域2:在线安装 区域3:从硬盘安装,即针对你已经下载好了的插件,可通过 ...

  5. 深入分析Spring混合事务

    在ORM框架的事务管理器的事务内,使用JdbcTemplate执行SQL是不会纳入事务管理的. 下面进行源码分析,看为什么必须要在DataSourceTransactionManager的事务内使用J ...

  6. 15个易遗忘的java知识点

    1.java中的基本数据类型以及所占内存大小 (1)整形  byte 1字节  short 2字节  int 4字节  long 8字节  (2)浮点型  float 4字节  double 8字节  ...

  7. 初次见面 你好EF

    EF(yif),第一次听到这个名字的时候,以为是一个帅帅的魔术师,在小编的傻傻的梦想里,就是有一天,有一个魔术师站在小编面前,变出一大捧的玫瑰花,然后,然后不要钱`(*∩_∩*)′,然而在我们的编程世 ...

  8. 精通CSS+DIV网页样式与布局--CSS段落效果

    在上一篇博文中,小编主要详细的介绍了CSS是如何控制文字的显示效果,随着需求的不断变更,那么我们如何对段落进行相关操作,以达到我们想要的效果呢,接下来,为了需要,小编继续来完善CSS对段落的控制的显示 ...

  9. (六十九)使用block进行消息传递

    在两个类之间进行消息传递,一般通过代理或者block进行,代理写起来较为麻烦,block较为简单,但是block需要特别注意内存泄漏问题,注意self和block之间要为弱引用,下面介绍使用block ...

  10. 学习TensorFlow,邂逅MNIST数据集

    如果说"Hello Word!"是程序员的第一个程序,那么MNIST数据集,毫无疑问是机器学习者第一个训练的数据集,本文将使用Google公布的TensorFLow来学习训练MNI ...