oracle的安装与卸载
- 要记住数据库口令,适用于sys、system.sysman/dbsnmp等账户,而scott帐号密码默认为tiger, 以oracle 10g来说,scott账户默认是lock的,需要unlock,
解决方法:1.即需要登录自带客户端即SQL plus登录sys等账户,口令为“密码【空格】as【空格】sysdba” 比如口令 “a3814194 as sysdba” 注意空格,因为输入的是密码,输入的是*号,空格必须打,否则密码错误。
2.下载个PLSQL Developer 开发工具,输入sys和密码再选中sysdba数据库即可登录。
3. 在(1)或(2)登录sys账户后,输入命令行: alter user scott account unlock; 解锁即可。
- 安装好之后,需要开启服务才能使用数据库,右击计算机选择管理,选择服务,启动“OracleOraDb10g_home1TNSListener” 监听器服务 和“OracleServiceORCL”数据库服务
卸载
- 彻底删除oracle :http://wenku.baidu.com/link?url=BKH21ClE4dr6T3wnm41RjnTV6A5niPVZOrLc3Iie0OBwCdE6T9w2fYSRUoE1EEemwcWhRJAupR3IfzlPjw6ZcGybMcRTyKleziCtKboh0kS
oracle的使用
- 注释语句: --
- 创建表空间: 不能是scott账户,因为这个账户是测试账户没有权限创建表空间。需要系统管理员才有权限,返回登录数据库选择sysdba,账户密码随便填即可(因为服务器在本机上,所以在本机登录sysdba可以随便填账户密码,如果是在别的机器,则乱填报错),登陆之后,输入命令:
create tablespace sp_student datafile 'F:\test\test.mdf' size 100m;
datafile 'F:\test\test.mdf'表示创建的文件存放在F:\test文件夹下,文件名叫test.mdf(执行语句之后在F:\test下自动生成test.mdf文件),注意 test文件夹必须存在,否则报错。
size表示文件大小。
当表空间容量100M用完之后或者磁盘容量耗尽,我们可以继续扩容,
alter tablespace sp_student add datafile 'E:\text1\text1.mdf' size 10m;
这样在E:\text1目录下会生成text1.mdf文件,当表空间或者磁盘容量用完之后,我们可以在其他擦盘继续创建空间来容纳数据。
- 我们开发了一个系统之后,如果这个系统要使用数据库,则一般会创建一个用户。
--创建用户 create user myUse identified by a3814194 default tablespace sp_student;
--删除用户
drop user myUse;
--给予权限 grant resource to myUse;
--回收权限
revoke resource from myUse;
create user+用户名,identified by +密码, 创建完用户之后,需要给这个用户权限,比如登录权限,创建表修改表等等权限,我们可以直接resource 这个权限给用户(必须是管理员帐号才能赋予权限),
这个用户就可以登录、创建表等等。
- 切换用户登录,登录myUse用户
- 创建表 :
--创建表 create table student ( sno ), name ), birthday date );
--查看表
select * from student;
--删除表
drop table student;
- 修改表:
--修改表/增加列 alter table student add sex ); ----修改表/删除列 alter table student drop column sex;
增加列add 不用加column 而修改列add 要接column 且只要列名
--修改列的类型
alter table student modify sno date;
- 表创建完之后,我们可以对这张表进行增加、删除、修改数据等操作。
insert into student values(','张三',to_date('1990/10/29','yyyy/MM/dd'));
插入一条记录,to_date()函数用于日期型数据转换为特定格式,在mysql中1990/10/29这种格式可以直接插入,而在oracle中要转换为yyyy/MM/dd格式才能插入
.当我们插入数据成功之后,要对操作进行commit,否则数据并未真正提交,这时候如果再创建一个数据库登录myUse用户,查看数据库student表会发现数据并未插入。
我们也可以选择对某些列插入数据,如下,如果没有(sno)则默认对所有列插入数据.
insert into student(sno) values(');
--修改数据 update student ';
--删除数据 ';
- 如果我们插入一条数据delete from student where sno='002'; 这样的数据是没有任何价值的,为了确定插入的数据必须是有价值的,我们需要对插入的数据进行约束,即插入的数据必须满足某些条件才能插入,即实现数据完整性(约束条件):非空、主键(非空+唯一+聚集索引)、唯一、检查、外键、默认值。
--约束条件
--主键约束 alter table student add constraint pk_sno primary key(sno);pk_sno为约束条件名,注意如果表里有数据,且又增加某个约束条件,如果表里的数据跟约束条件冲突的时候会报错,比如数据库里已经有了一条sno为空的数据,而此时我们又对sno增加了主键约束条件,那么增加约束条件这步无法执行。
--非空 alter table student modify name ) not null;
--检查约束
alter table student add constraint ck_birthday check(birthday between to_date('1900/01/01','yyyy/MM/dd') and to_date('2000/01/01','yyyy/MM/dd'));
--在表定义时定义检查约束
create table s(
id int primary key,
sex char(10) check (sex in ('男' , '女'))
);
--唯一性约束 alter table student add constraint un_name unique(name);
--默认值 alter table student modify name ) default 'sb';
- 外键约束 :外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。
为了实验外键约束我们需要创建一张新表
create table score ( id int primary key, name ), sno ), foreign key(sno) references student(sno) );
原来的student表里有两条记录,sno=001 name=张三 birthday=1990/10/29 ; sno=002 name=sb birthday=1911/01/01
score表里 sno为外键,如果往score表里插入一条数据 :insert into score values(1,'王五','003');
则报错,因为sno是外键,而student表里没有sno=003 这条记录。