Oracle零碎知识

来源:互联网 发布:做网站是否用数据库 编辑:程序博客网 时间:2024/05/21 23:43

 


//给用户phpls授权

GRANT 
    CREATE  SESSION,  CREATE   ANY   TABLE ,  CREATE   ANY   VIEW  , CREATE   ANY   INDEX ,  CREATE   ANY   PROCEDURE ,
    ALTER   ANY   TABLE ,  ALTER   ANY   PROCEDURE ,
    DROP   ANY   TABLE ,  DROP   ANY   VIEW ,  DROP   ANY   INDEX ,  DROP   ANY   PROCEDURE ,
    SELECT   ANY   TABLE ,  INSERT   ANY   TABLE ,  UPDATE   ANY   TABLE ,  DELETE   ANY   TABLE
    TO phpls;

grant connect,resource,dba to phpls;
grant role to phpls;
grant drop tablespace to phpls;


//删除用户
drop user 用户名 cascade ;

//增加表空间
alter tablespace chinawater add datafile '地址'
size 200M

//创建空间
create tablespace test datafile 'C:/oracle/oradata/orcl10/test.dbf'
size 100M default storage(initial 500K next 500K minextents 1 maxextents unlimited pctincrease 0);

//创建用户权限
create user phpls identified by phpls default tablespace test;


//tomcat的启动和清理
ant deploy
ant clean

 

 

数据的导出、导入:

oracle建立自己的表: 

在安全性中建立一个用户zhouli,密码111 

在存储中建立表空间zhouli 

把用户zhouli的表空间指定为刚刚建立的表空间zhouli,然后在角色中添加dba角色这样可以导入导出表  

oracle 导出webuser中的表  :

exp webuser/htdzwebconnect@htmis file=zl owner=webuser 

这样导出到文件zl.dmp中 

导入到我的zhouli用户中,这样在方案中可以使用zhouli的表了 
imp zhouli/111@htmis file=zl.dmp fromuser=webuser 
注意fromuser是刚刚导出的用户webuser.  
删除:先删除用户zhouli 
再删除表空间 


下面介绍的是导入导出的实例,导入导出看实例基本上就可以完成,因为导入导出很简单。
 
------------------数据导出:--------------------
 
 1 将 数据库TEST 完全导出,用户名system 密码manager 导出到D:/daochu.dmp中 
   exp system/manager@TEST file=d:/daochu.dmp full=y 

 2 将数据库中system用户与sys用户的表导出 
   exp system/manager@TEST file=d:/daochu.dmp owner=(system,sys) 

 3 将数据库中的表table1 、table2导出 
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1,table2) 
 
 4 将数据库中的表table1中的字段filed1以"00"打头的数据导出 
   exp system/manager@TEST file=d:/daochu.dmp tables=(table1) query=/" where filed1 like ’00%’/" 
   
上面是常用的导出,对于压缩我不太在意,用winzip把dmp文件可以很好的压缩。 
不过在上面命令后面 加上 compress=y  就可以了 


---------------------数据的导入:--------------------

 1 将D:/daochu.dmp 中的数据导入 TEST数据库中。 
   imp system/manager@TEST  file=d:/daochu.dmp 

   上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。 
   在后面加上 ignore=y 就可以了。
 
 2 将d:/daochu.dmp中的表table1 导入 
 imp system/manager@TEST  file=d:/daochu.dmp  tables=(table1)  

 3 将按照用户(owner=a)导出的表文件 file=d:/daochu.dmp 导入到用户b的所在表空间中 
 imp userid=b/pwd file=d:/daochu.dmp fromuser=a touser=b logs=d:/xx.log

 

常用创建语句:

    1.创建表

  create table 表名(

  列名1 类型,

  列名2 类型

  );

  2.修改类属性

  alter table 表名 modify(列名 类型);

  3.添加列

  alter table 表名 add(列名 类型);

  4.添加主键约束和非空约束

  alter table 表名 add constraint pk_表名 primary key(列名);

  alter table 表名 modify(列名 not null);

  5.删除主键约束

  alter table 表名 drop primary key;

  alter table 表名 drop constraint pk_表名;

  6.失效约束

  alter table 表名 disable primary key;

  alter table 表名 disable constraint pk_表名;

  7.有效约束

  alter table 表名 enable primary key;

  alter table 表名 enable constraint pk_表名;

  8.删除列

  alter table 表名 drop column 列名;

  9.设置某列不可用,然后删除

  alter table 表名 set unused(列名);

  alter table 表名 drop unused columns;

  10.修改表名

  rename 表名1 to 表名2

  alter 表名1 rename to 表名2;

    11.截断表

  truncate table 表名;

  12.截断表保留行空间

  truncate table 表名 resue storage;

  13.查看表结构

  desc table 表名;

  14.删除表

  drop table 表名;

  15.插入记录

  例:insert into 表名 values(内容1,内容2,内容3,内容4);

  16.带参数对话方式插入行

  例:insert into 表名 values(&列名1,&列名2);

  insert into 表名 values(内容1,内容2);

  17.插入某几列记录

  insert into 表名(列名1,列名2) values(内容1,内容2);

  18.为列插入空值(其列不能为not null)

  insert into 表名 values(内容1,null,null);

  19.创建表(包括主键及外键设置)方法一

  create table 表名(

  列名1 类型

  constraint pk_表名 primary key,

  列名2 类型 not null,

  列名3 类型

  constraint fk_表名 reference 表名(列名),

  列名3 类型

  constraint ck_表名 check(列名3 in(''内容1'',''内容2'',''内容3''))

  );

  20.查询所有行

  select * from 表名;

  21.查询某几列

  select 列名1,列名2 from 表名;

  22.重复行消除

  select distict 列名 from 表名;

  23.where语句查询

  select * from 表名 where 条件 order by 列名;

  (注:如number类型查出自动按升序排列,如要按降序排列,则select * from 表名 where 条件 order by 列名 desc;)

    24.创建表,方法二

  create table 表名(

  列名1 类型 primary key,

  列名2 类型 not null,

  列名3 类型 check(列名3 in('''','''','''')),

  列名4 类型 refernce 表名(列名)

  );

  25.修改 列=‘?’的数据

  update 表名 set (列=?) where 列=‘?’;

  26.删除行

  delete from 表名 where 条件;

  27.事务处理

  --事务处理

  update 表名

  set 列名(日期) = ''30-5月-98''

  where 条件;

  savepoint mark1;

  delete from 表名 where 条件;

  savepoint mark2;

  rollback to savepoint mark1;

  rollback;

  28.建立用户user1,密码为password

  授予用户connect,resource的权限

  connect角色用于登录

  resource角色用于建表等.

  connect system/manager

  create user user1 identified by password;

  grant connect,resource to password;

  29.数据控制语言

  connect scott/tiger

  30.把对表1查询和修改的权限授予user1

  grant select,update on 表1 to user1;

  31.把对表表1中列1和列2修改的权限授予user1

  grant update(列1,列2) on 表1 to user1;

  32.把对表表1查询的权限授予用户user1

  并且user1用户还可以把这个权限授予别的用户(with grant option)

  grant select on 表1 to user1 with grant option;

  33.从用户user1撤销对表1查询和修改的权限

  revoke select,update on 表1 from user1;

 

 

 

查询一下Oracle数据库下所有的表名或某个用户下的所有表:

 

select table_name from all_tables;//所有的表明

select table_name from user_all_tables;//用户的所有的表

    1.查询:
   
    select * from user_objects;               //查询所有的表

  select * from dba_tables;                   //查询所有的表

  select * from all_tables;                  //查询所有的表

  select * from user_users                  //查出一个用户

  select * from all_users                     //查询所有用户

  select * from dba_users                     //查询所有用户

  select name,dbid from v$database;         //查询数据库名和它的ID

  select * from sys.user_tab_columns;         //查询表名 ,并显示列名

  describe 表名                             //查询表结构

  select * from sys.user_tab_columns where table_name=表名 //查询指定表名的字段

  2: 查询数据库参数

  show parameter db;

  3:查询数据库的实例名

  select instance_name from v$instance;

  4: 数据库域名

  数据库安装结束后,如果要知道正在运行额数据库是否有域名以及数据库域名名称可以用

  select value from v$parameter where name='db_domain'

  show parameter domain

  5:数据库服务名

  如果数据库有域名,则数据库服务名就是全局数据库名,如果该数据库没有定义域名,则数据库服务名与数据库名相同

  show parameter service_name

  6:显示当前用户

  show user

  7:直接登陆

  sqlplus "/as sysdba"

  8:当前ORACLE系统时间

  select sysdate from dual;

 

 

常用的sql*plus命令:
  
  1. 执行一个SQL脚本文件
  SQL>start file_name
  SQL>@ file_name
  我们可以将多条sql语句保存在一个文本文件中,这样当要执行这个文件中的所有的sql语句时,用上面的任一命令即可,这类似于dos中的批处理。
  
  2. 对当前的输入进行编辑
  SQL>edit
  
  3. 重新运行上一次运行的sql语句
  SQL>/
  
  4. 将显示的内容输出到指定文件
  SQL> SPOOL file_name
  在屏幕上的所有内容都包含在该文件中,包括你输入的sql语句。
  
  5. 关闭spool输出
  SQL> SPOOL OFF
  只有关闭spool输出,才会在输出文件中看到输出的内容。
  
  6.显示一个表的结构
  SQL> desc table_name
  
  7. COL命令:
  主要格式化列的显示形式。
  该命令有许多选项,具体如下:
  COL[UMN] [{ column|expr} [ option ...]]
  Option选项可以是如下的子句:
  ALI[AS] alias
  CLE[AR]
  FOLD_A[FTER]
  FOLD_B[EFORE]
  FOR[MAT] format
  HEA[DING] text
  JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}
  LIKE { expr|alias}
  NEWL[INE]
  NEW_V[ALUE] variable
  NOPRI[NT]|PRI[NT]
  NUL[L] text
  OLD_V[ALUE] variable
  ON|OFF
  WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]
  
  1). 改变缺省的列标题
  COLUMN column_name HEADING column_heading
  For example:
  Sql>select * from dept;
  DEPTNO DNAME            LOC
  ---------- ---------------------------- ---------
  10 ACCOUNTING          NEW YORK
  sql>col LOC heading location
  sql>select * from dept;
  DEPTNO DNAME            location
  --------- ---------------------------- -----------
  10 ACCOUNTING          NEW YORK
  
  2). 将列名ENAME改为新列名EMPLOYEE NAME并将新列名放在两行上:
  Sql>select * from emp
  Department name      Salary
  ---------- ---------- ----------
  10 aaa        11
  SQL> COLUMN ENAME HEADING ’Employee|Name’
  Sql>select * from emp
  Employee
  Department name      Salary
  ---------- ---------- ----------
  10 aaa        11
  note: the col heading turn into two lines from one line.
  
  3). 改变列的显示长度:
  FOR[MAT] format
  Sql>select empno,ename,job from emp;
  EMPNO ENAME   JOB
  ---------- ----------   ---------
  7369 SMITH   CLERK
  7499 ALLEN   SALESMAN
  7521 WARD    SALESMAN
  Sql> col ename format a40
  EMPNO ENAME                  JOB
  ----------  ----------------------------------------     ---------
  7369 SMITH                  CLERK
  7499 ALLEN                  SALESMAN
  7521 WARD                  SALESMAN
  
  4). 设置列标题的对齐方式
  JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}
  SQL> col ename justify center
  SQL> /
  EMPNO      ENAME          JOB
  ----------  ----------------------------------------    ---------
  7369 SMITH                  CLERK
  7499 ALLEN                  SALESMAN
  7521 WARD                   SALESMAN
  对于NUMBER型的列,列标题缺省在右边,其它类型的列标题缺省在左边
  
  5). 不让一个列显示在屏幕上
  NOPRI[NT]|PRI[NT]
  SQL> col job noprint
  SQL> /
  EMPNO      ENAME
  ----------   ----------------------------------------
  7369 SMITH
  7499 ALLEN
  7521 WARD
  
  6). 格式化NUMBER类型列的显示:
  SQL> COLUMN SAL FORMAT $99,990
  SQL> /
  Employee
  Department Name    Salary  Commission
  ---------- ---------- --------- ----------
  30     ALLEN    $1,600  300
  
  7). 显示列值时,如果列值为NULL值,用text值代替NULL值
  COMM NUL[L] text
  SQL>COL COMM NUL[L] text
  
  8). 设置一个列的回绕方式
  WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]
  COL1
  --------------------
  HOW ARE YOU?
  
  SQL>COL COL1 FORMAT A5
  SQL>COL COL1 WRAPPED
  COL1
  -----
  HOW A
  RE YO
  U?
  
  SQL> COL COL1 WORD_WRAPPED
  COL1
  -----
  HOW
  ARE
  YOU?
  
  SQL> COL COL1 WORD_WRAPPED
  COL1
  -----
  HOW A
  
  9). 显示列的当前的显示属性值
  SQL> COLUMN column_name
  
  10). 将所有列的显示属性设为缺省值
  SQL> CLEAR COLUMNS
  
  8. 屏蔽掉一个列中显示的相同的值
  BREAK ON break_column
  SQL> BREAK ON DEPTNO
  SQL> SELECT DEPTNO, ENAME, SAL
  FROM EMP
  WHERE SAL < 2500
  ORDER BY DEPTNO;
  DEPTNO   ENAME     SAL
  ---------- ----------- ---------
  10      CLARK    2450
  MILLER   1300
  20      SMITH    800
  ADAMS    1100
  
  9. 在上面屏蔽掉一个列中显示的相同的值的显示中,每当列值变化时在值变化之前插入n个空行。
  BREAK ON break_column SKIP n
  
  SQL> BREAK ON DEPTNO SKIP 1
  SQL> /
  DEPTNO ENAME SAL
  ---------- ----------- ---------
  10 CLARK 2450
  MILLER 1300
  
  20 SMITH 800
  ADAMS 1100
  
  10. 显示对BREAK的设置
  SQL> BREAK
  
  11. 删除6、7的设置
  SQL> CLEAR BREAKS
  
  12. Set 命令:
  该命令包含许多子命令:
  SET system_variable value
  system_variable value 可以是如下的子句之一:

  APPI[NFO]{ON|OFF|text}
  ARRAY[SIZE] {15|n}
  AUTO[COMMIT]{ON|OFF|IMM[EDIATE]|n}
  AUTOP[RINT] {ON|OFF}
  AUTORECOVERY [ON|OFF]
  AUTOT[RACE] {ON|OFF|TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]
  BLO[CKTERMINATOR] {.|c}
  CMDS[EP] {;|c|ON|OFF}
  COLSEP {_|text}
  COM[PATIBILITY]{V7|V8|NATIVE}
  CON[CAT] {.|c|ON|OFF}
  COPYC[OMMIT] {0|n}
  COPYTYPECHECK {ON|OFF}
  DEF[INE] {&|c|ON|OFF}
  DESCRIBE [DEPTH {1|n|ALL}][LINENUM {ON|OFF}][INDENT {ON|OFF}]
  ECHO {ON|OFF}
  EDITF[ILE] file_name[.ext]
  EMB[EDDED] {ON|OFF}
  ESC[APE] {/|c|ON|OFF}
  FEED[BACK] {6|n|ON|OFF}
  FLAGGER {OFF|ENTRY |INTERMED[IATE]|FULL}
  FLU[SH] {ON|OFF}
  HEA[DING] {ON|OFF}
  HEADS[EP] {||c|ON|OFF}
  INSTANCE [instance_path|LOCAL]
  LIN[ESIZE] {80|n}
  LOBOF[FSET] {n|1}
  LOGSOURCE [pathname]
  LONG {80|n}
  LONGC[HUNKSIZE] {80|n}
  MARK[UP] HTML [ON|OFF] [HEAD text] [BODY text] [ENTMAP {ON|OFF}] [SPOOL
  {ON|OFF}] [PRE[FORMAT] {ON|OFF}]
  NEWP[AGE] {1|n|NONE}
  NULL text
  NUMF[ORMAT] format
  NUM[WIDTH] {10|n}
  PAGES[IZE] {24|n}
  PAU[SE] {ON|OFF|text}
  RECSEP {WR[APPED]|EA[CH]|OFF}
  RECSEPCHAR {_|c}
  SERVEROUT[PUT] {ON|OFF} [SIZE n] [FOR[MAT] {WRA[PPED]|WOR[D_
  WRAPPED]|TRU[NCATED]}]
  SHIFT[INOUT] {VIS[IBLE]|INV[ISIBLE]}
  SHOW[MODE] {ON|OFF}
  SQLBL[ANKLINES] {ON|OFF}
  SQLC[ASE] {MIX[ED]|LO[WER]|UP[PER]}
  SQLCO[NTINUE] {> |text}
  SQLN[UMBER] {ON|OFF}
  SQLPRE[FIX] {#|c}
  SQLP[ROMPT] {SQL>|text}
  SQLT[ERMINATOR] {;|c|ON|OFF}
  SUF[FIX] {SQL|text}
  TAB {ON|OFF}
  TERM[OUT] {ON|OFF}
  TI[ME] {ON|OFF}
  TIM

 

原创粉丝点击