Oracle数据库操作

--查询员工表数据
select * from emp;

--创建表空间
create tablespace sp_java1608
datafile ‘e:\data\data1.mdf‘ size 100 M;

--修改表空间

--空间变为200M
alter tablespace sp_java1608
add datafile ‘e:\data\data2.mdf‘ size 100 M;

--删除表空间
drop tablespace sp_java1608 including contents and datafiles;

--创建用户(create user username identified by password)设置默认表空间

create user java1608
identified by java1608
default tablespace sp_java1608;

--删除用户
drop user java1608;

--赋予权限:

--connect :可以登录Oracle,不可以创建实体,不可以创建数据库结构。

--session 创建会话的权限

--DBA:拥有全部特权

--RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构

grant create session to java1608;

grant create connect to Java1608;

grant resource to java1608;

--回收权限
revoke resource from java1608;

--rowID,rownum   都是伪列

--rowid在数据库中具有唯一性,在同一个数据库中是不会重复的,而rownum则可以理解为行号。
--常用于数据库分页
--如下例子:3当前是第几页,2代表每页显示几条数据
select * from
(
select rownum as eid,emp.* from emp
) tmp where eid between (3*2)+1 and (3+1)*2;

--单表查询
--select 列名1,列名2,... from 表名 where 条件

select * from emp;

select ename,sal from emp;

select * from emp where empno = 7369;

--distinct 除去列名重复

select distinct job from emp;

--oracle默认是隐式事务
--插入数据
insert into emp values(1000,‘张三‘,‘CLERK‘,7698,to_date(‘2000/01/01‘,‘yyyy/mm/dd‘),300.5,100.6,20);

insert into emp values(1001,‘lisi‘,‘CLERK‘,7698,to_date(‘2000/01/01‘,‘yyyy/mm/dd‘),300.5,100.6,20);

--rollback为撤回行为 与之相对的为commit提交事务

rollback;

--计算列
select ename,sal+comm as totalsal from emp where comm is not null;

select * from emp where ename like ‘%E%‘;

select * from emp where ename like ‘%E_‘;-- _伟%

--连接运算符

--dual 是为了让查询语法完成而存在的关键字
select ‘a‘ || ‘b‘ from dual;

--聚合函数,数据库通用函数 
select min(sal) from emp;

select job, max(sal) from emp group by job having max(sal)>=2000;

select avg(sal) from emp;

select sum(sal) from emp;

select count(*) from emp;

--创建表
create table t_student
(
sno char(10),
name nvarchar2(6),
sex char(1),
address varchar2(200),
birthday date
);

select * from t_student;

insert into t_student(sex) values(‘m‘);

--数据完成整性
--修改表/增加列
alter table t_student
add mphone char(11);

--修改表/修改列
alter table t_student
modify mphone char(12) not null;

--修改表/删除列
alter table t_student
drop column mphone;

--表改名
alter table t_student_1
rename to t_student;

--删除表
drop table t_student;

--实体完整性\域完整性\引用完整性(约束来实现)
--主键约束(非空,唯一,聚焦索引)
alter table t_student
add constraint pk_student_sno primary key (sno);

--非空约束
alter table t_student
modify name varchar2(6) not null;

alter table t_student
modify sex not null;

--默认值约束
alter table t_student
modify sex default ‘m‘;

--唯一性约束
alter table t_student
add constraint un_student_name unique (name);

--检查性约束

--between为前后闭区间
alter table t_student
add constraint ck_student_sex check (sex=‘m‘ or sex =‘f‘);

alter table t_student
add constraint ck_student_birthday check (birthday between to_date(‘1900/01/01‘,‘yyyy/mm/dd‘) and to_date(‘2016/11/27‘,‘yyyy/mm/dd‘));

--外键约束

--主键(主表);外键 (从表)

alter table t_score
add constraint fk_score_sno foreign key (sno) references t_student(sno);

create table t_score
(
sid int primary key,
math int not null,
chenese int not null,
sno char(10) 
) ;

select * from t_score;

--删除表所有数据

delete from t_score;

--关联表数据一一对应

insert into t_score values(1,20,30,‘s001‘);
insert into t_score values(2,20,30,‘s002‘);
insert into t_score values(3,20,30,‘s003‘);
insert into t_score values(4,20,30,‘s004‘);

insert into t_student(sno,name,sex,birthday) values(‘s001‘,‘zhang‘,‘f‘,to_date(‘1900/01/01‘,‘YYYY/MM/DD‘));
insert into t_student(sno,name,sex,birthday) values(‘s002‘,‘li‘,‘m‘,to_date(‘1900/01/01‘,‘YYYY/MM/DD‘));
insert into t_student(sno,name,sex,birthday) values(‘s003‘,‘zhao‘,‘f‘,to_date(‘1900/01/01‘,‘YYYY/MM/DD‘));
insert into t_student(sno,name,sex,birthday) values(‘s004‘,‘wang‘,‘m‘,to_date(‘1900/01/01‘,‘YYYY/MM/DD‘));

select * from t_student;

delete from t_student;

时间: 2024-08-25 22:31:49

Oracle数据库操作的相关文章

基于OCILIB的oracle数据库操作总结及自动生成Model和Dao的工具

基于OCILIB的oracle数据库操作总结 1.       类图 2.       基类BaseOCIDao的设计与实现 BaseOCIDao.h头文件 #pragma once /* --------------------------------------------------------------------------------------------- * * INCLUDES * ----------------------------------------------

查询ORACLE数据库操作记录

代码: SELECT a.First_Load_Time,        a.Sql_Text,        s.Sid,        s.Serial#,        s.Program --,        ,        a.* --       Utl_Inaddr.Get_Host_Address(s.Terminal) Ip   FROM V$sqlarea a, V$session s  WHERE s.Sql_Address(+) = a.Address    AND U

C# Oracle数据库操作类实例详解

本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长度等,同时还有哈稀表自动插入数据库等高级任务.需要特别指出的是:在执行SQL语句,返回 DataReader之前一定要先用.read()打开,然后才能读到数据,再用hashTable对数据库进行insert,update,del操作,注意此时只能用默认的数据库连接"connstr". 本文

oracle数据库操作语句

常用到的oracle数据库操作语句,以下仅供参考: 一. 查询 1.查询某个数据库表大于某个日期的所有数据条数    select count(*) from ALARM_LOG t where t.ALARM_START_TIME> to_date('2017-01-10 08:00:00','yyyy-mm-dd hh24:mi:ss');   查询某个数据库表大于某个日期的所有历史数据  select * from ALARM_LOG t where t.ALARM_START_TIME>

(转)C# Oracle数据库操作类

原文地址:http://www.cnblogs.com/haibing0107/p/6143922.html using System;using System.Data;using System.Collections.Generic;using System.Configuration;using System.Data.OracleClient;using System.Text;using System.IO; /// <summary>  /// Oracle数据库操作类  ///

Oracle数据库操作知道

SELECT TGTID,PHONENUM,REGISTERDATE ,to_date(REGISTERDATE,'YYYY-MM-DD HH24:MI:SS') AS T FROM WTRESSENWEB.T_AXMALL_COMMONCLIENT WHERE TGTID = '2087' AND to_date(REGISTERDATE,'YYYY-MM-DD HH24:MI:SS') > to_date('2014-07-09','yyyy-mm-dd'); 对于to_char() to_

oracle数据库 操作clob对象

clob类型,但对于这个类型处理起来还是比较麻烦的,varchar2长度为4000bytes,如果varchar2能满足楼主的需求,建议使用varchar2,下面提供了在Java 中读取clob类型的方式,我主要讲的是JDBC的操作,Hibernate目前不讲,操作这个Clob列主要分为插入和获取俩个操作:1.Java程序插入Clob值到Oracle数据库表中:   String clob= "这里主要是要插入到表中的值";     //前面具体数据库连接代码这里省略,直接进正题  

Python实战之Oracle数据库操作

1. 要想使Python可以操作Oracle数据库,首先需要安装cx_Oracle包,可以通过下面的地址来获取安装包 [plain] view plain copy http://cx-oracle.sourceforge.net/ 2. 另外还需要oracle的一些类库,此时需要在运行python的机器上安装Oracle Instant Client软件包,可以通过下面地址获得 [plain] view plain copy http://www.oracle.com/technetwork/

Oracle 数据库操作

---恢复内容开始--- 现在大型企业一般都用Oracle数据库,Oracle数据库在一般采用expdp,impdp 导出导入数据,但是在操作中经常会遇到一些问题.下面来浅析这些问题. 1. 导出数据 一般导出数据的时候需要建立一个目录地址 select * from dba_directories; --查询所有目录地址create or replace directory winqt_dump as '/home/front/dmpfile'; --创建目录地址grant read,writ

实现c# 直接连接Oracle数据库操作,不用安装各种插件

在c#中连接oracle数据库,遭遇了各种痛苦. 采用VS默认的方式连接oracle发现有版本限制,而且还需要安装oracle的客户端,否则连接不了.客户端的版本与Oracle数据库的版本对接不上也连接不了. 在网上也找了很多,尝试过使用ODP.NET来连接,发现一样不行,就连引用dll后,一跑就会报错.麻烦死了. 最终,找到了一种方法,使用第三方的库来实现,找了一个破解版的.测试之后可行,不需要安装客户端,也不需要安装其他的,直接就可以连接上了. 测试环境: PC机:WIN7 64位,安装有o