为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

Oracle_SQL语法查询

2013-09-12 28页 doc 214KB 28阅读

用户头像

is_426809

暂无简介

举报
Oracle_SQL语法查询一、数学函数 SELECT ROUND(123.35) FROM DUAL;//123 SELECT TRUNC(123.45) FROM DUAL;//123 SELECT ROUND(123.45,-1) FROM DUAL;//120 SELECT TRUNC(123.45,-1) FROM DUAL;//120 二、字符串函数 SELECT LENGTH('HELLO') FROM DUAL;//5 SELECT LPAD('ABC',5,'*') FROM DUAL;//**ABC SELECT REPLACE(...
Oracle_SQL语法查询
一、数学函数 SELECT ROUND(123.35) FROM DUAL;//123 SELECT TRUNC(123.45) FROM DUAL;//123 SELECT ROUND(123.45,-1) FROM DUAL;//120 SELECT TRUNC(123.45,-1) FROM DUAL;//120 二、字符串函数 SELECT LENGTH('HELLO') FROM DUAL;//5 SELECT LPAD('ABC',5,'*') FROM DUAL;//**ABC SELECT REPLACE('ABCDEFG','DE','WW') S1,REPLACE('ABCDEFG','DE') S2 FROM DUAL; SELECT SUBSTR('ABCDEFG',1,3) S1,SUBSTR('ABCDEFG',5,5) S2 FROM DUAL; 三、日期函数 SELECT TO_CHAR(SYSDATE,'DD-MON-YY HH:MI:SS'),ADD_MONTHS(SYSDATE,3) FROM DUAL; SELECT SYSDATE,LAST_DAY(SYSDATE),LAST_DAY(SYSDATE) + 1 FROM DUAL; SELECT MONTHS_BETWEEN(SYSDATE,'25-12月-06') FROM DUAL; SELECT NEXT_DAY(SYSDATE,'星期一') FROM DUAL; 1.创建用户 connect system/manager@eis create user oracle_admin identified by oracle_admin; grant connect,dba to oracle_admin; alter user oracle_admin default tablespace users quota unlimited on users; alter user oracle_admin temporary tablespace temp; 2.修改密码 connect oracle_admin/oracle_admin@eis alter user oracle_admin identified by welcome; 3.解除账号锁定 connect oracle_admin/oracle_admin@eis alter user oe account unlock; connect oe/oe@eis; 4.修改表空间设置(将默认表空间设置为user,临时表空间为temp) select tablespace_name,contents from dba_tablespaces order by tablespace_name; alter user hr default tablespace users temporary tablespace temp; 5.修改表空间配额 connect oracle_admin/oracle_admin@eis alter user hr quota unlimited on users quota 10M on temp quota 0M on system; 6.建立和删除用户 connect oracle_admin/oracle_admin@eis create user dropme identified by doomed default tablespace users temporary tablespace temp quota unlimited on users; grant create table,create session to dropme; connect dropme/doomed@eis create table demo (name varchar2(20)) connect oracle_admin/oracle_admin@eis drop user dropme cascade; 7.处理日期数据 connect oracle_admin/oracle_admin create table test1 (name varchar2(20),birth date); insert into test1(name,birth) values('zhangliyong',to_date('1972-10-28','yyyy-mm-dd')); select * from test1; 8.处理timestamp connect oracle_admin/oracle_admin create table test2 (name varchar2(20), birth date, t_timestamp timestamp); insert into test2(name,birth,t_timestamp) values('zhangliyong',sysdate,sysdate); commit; select * from test2; insert into test2(name,birth,t_timestamp) values('sun',sysdate,timestamp'2002-02-22 18:00:03.000123 pst'); commit; select * from test2; 9.判断我们所处的时区 select dbtimezone from dual; 一、创建表结构 1、创建新表 CREATE TABLE 表名 ( 列名 数据类型 [默认值|NOT NULL] 约束, 列名 数据类型 [默认值|NOT NULL] 约束, ... ) 2、复制表(带数据) CREATE TABLE 表名1 AS SELECT * FROM 表名2; 3、复制表结构(不带数据) CREATE TABLE 表名1 AS SELECT * FROM 表名2 WHERE 1 = 2; 二、修改表结构 1、添加列: ALTER TABLE 表名 ADD 列名 数据类型 [默认值|NOT NULL] 约束; 2、修改列 ALTER TABLE 表名 MODIFY 列名 数据类型 [默认值|NOT NULL] 约束; 3、删除列 ALTER TABLE 表名DROP COLUMN 列名 4、给表重命名 ALTER TABLE 表名 RENAME TO 新表名; 5、给列重命名 ALTER TABLE 表名 RENAME COLUMN 列名 TO 新列名; 6、给列添加约束(主键、外键、唯一、检查) ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束类型(列名); 约束类型:PRIMARY KEY/FOREIGN KEY/CHECK/UNIQUE 7、删除约束 ALTER TABLE 表名 DROP CONSTRAINT 约束名; 8、启用或禁用约束 ALTER TABLE 表名 DISABLE|ENABLE CONSTRAINT 约束名; 9、把表放在或取出数据库的内存区 ALTER TABLE 表名 CACHE|NOCACHE; 三、删除表结构 DROP TABLE 表名CASCADE CONSTRAINTS; 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); INSERT INTO 表名(字段名1, 字段名2, ……) SELECT (字段名1, 字段名2, ……) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’ 如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个单引号''. 字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验. 日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-DD’),TO_DATE()还有很多种日期格式, 可以参看ORACLE DOC. 年-月-日 小时:分钟:秒 的格式YYYY-MM-DD HH24:MI:SS INSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型, 方法借用ORACLE里自带的DBMS_LOB程序包. INSERT时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号 CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE; 其中最大的值按字段的长度来定, 如果定义的自动增长的序列NUMBER(6),最大值为999999 INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL 2.DELETE (删除数据表里记录的语句) DELETE FROM表名 WHERE 条件; 注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused. 如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间 TRUNCATE TABLE 表名; 此操作不可回退. 3.UPDATE (修改数据表里记录的语句) UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 条件; 如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验; 值N超过定义的长度会出错, 最好在插入前进行长度校验.. 注意事项: A. 以上SQL语句对表都加上了行级锁, 确认完成后, 必须加上事物处理结束的命令 COMMIT 才能正式生效, 否则改变不一定写入数据库里.如果想撤回这些操作, 可以用命令 ROLLBACK 复原. B. 在运行INSERT, DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围, 应该把它限定在较小 (一万条记录) 范围内,否则ORACLE处理这个事物用到很大的回退段. 程序响应慢甚至失去响应. 如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成, 其间加上COMMIT 确认事物处理. 1.CREATE (创建表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等) ORACLE常用的字段类型有: CHAR 固定长度的字符串 VARCHAR2 可变长度的字符串 NUMBER(M,N) 数字型M是位数总长度, N是小数的长度 DATE 日期类型 创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面 创建表时可以用中文的字段名, 但最好还是用英文的字段名 创建表时可以给字段加上默认值, 例如 DEFAULT SYSDATE 这样每次插入和修改时, 不用程序操作这个字段都能得到动作的时间 创建表时可以给字段加上约束条件 例如 不允许重复 UNIQUE, 关键字 PRIMARY KEY 2.ALTER (改变表, 索引, 视图等) 改变表的名称 ALTER TABLE 表名1 RENAME TO 表名2; 在表的后面增加一个字段 ALTER TABLE表名 ADD 字段名 字段名描述; 修改表里字段的定义描述 ALTER TABLE表名 MODIFY字段名 字段名描述; 给表里的字段加上约束条件 ALTER TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY (字段名); ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE (字段名); 把表放在或取出数据库的内存区 ALTER TABLE 表名 CACHE; ALTER TABLE 表名 NOCACHE; 3.DROP (删除表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等) 删除表和它所有的约束条件 DROP TABLE 表名 CASCADE CONSTRAINTS; 4.TRUNCATE (清空表里的所有记录, 保留表的结构) TRUNCATE 表名; SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 条件; 字段名可以带入函数 例如: COUNT(*), MIN(字段名), MAX(字段名), AVG(字段名), DISTINCT(字段名), TO_CHAR(DATE字段名,'YYYY-MM-DD HH24:MI:SS') NVL(EXPR1, EXPR2)函数 解释: IF EXPR1=NULL RETURN EXPR2 ELSE RETURN EXPR1 DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函数 解释: IF AA=V1 THEN RETURN R1 IF AA=V2 THEN RETURN R2 ..… ELSE RETURN NULL LPAD(char1,n,char2)函数 解释: 字符char1按制定的位数n显示,不足的位数用char2字符串替换左边的空位 字段名之间可以进行算术运算 例如: (字段名1*字段名1)/3 查询语句可以嵌套 例如: SELECT …… FROM (SELECT …… FROM表名1, [表名2, ……] WHERE 条件) WHERE 条件2; 两个查询语句的结果可以做集合操作 例如: 并集UNION(去掉重复记录), 并集UNION ALL(不去掉重复记录), 差集MINUS, 交集INTERSECT 分组查询 SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] GROUP BY字段名1 [HAVING 条件] ; 两个以上表之间的连接查询 SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 表名1.字段名 = 表名2. 字段名 [ AND ……] ; SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 表名1.字段名 = 表名2. 字段名(+) [ AND ……] ; 有(+)号的字段位置自动补空值 查询结果集的排序操作, 默认的排序是升序ASC, 降序是DESC SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] ORDER BY字段名1, 字段名2 DESC; 字符串模糊比较的方法 INSTR(字段名, ‘字符串’)>0 字段名 LIKE ‘字符串%’ [‘%字符串%’] 每个表都有一个隐含的字段ROWID, 它标记着记录的唯一性. 1.索引 (INDEX) CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] ); ALTER INDEX 索引名 REBUILD; 一个表的索引最好不要超过三个 (特殊的大表除外), 最好用单字段索引, 结合SQL语句的执行情况,也可以建立多字段的组合索引和基于函数的索引 ORACLE8.1.7字符串可以索引的最大长度为1578 单字节 ORACLE8.0.6字符串可以索引的最大长度为758 单字节 ORACLE DOC上说字符串最大可以建索引的长度约是:数据块的大小(db_block_size)*40% 2.视图 (VIEW) CREATE VIEW 视图名AS SELECT …. FROM …..; ALTER VIEW视图名 COMPILE; 视图仅是一个SQL查询语句, 它可以把表之间复杂的关系简洁化. 3.同义词 (SYNONMY) CREATE SYNONYM同义词名FOR 表名; CREATE SYNONYM同义词名FOR 表名@数据库链接名; 4.数据库链接 (DATABASE LINK) CREATE DATABASE LINK数据库链接名CONNECT TO 用户名 IDENTIFIED BY 密码 USING ‘数据库连接字符串’; 数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义. 数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样 数据库全局名称可以用以下命令查出 SELECT * FROM GLOBAL_NAME; 查询远端数据库里的表 SELECT …… FROM 表名@数据库链接名; 1.GRANT 赋于权限 常用的系统权限集合有以下三个: CONNECT(基本的连接), RESOURCE(程序开发), DBA(数据库管理) 常用的数据对象权限有以下五个: ALL ON 数据对象名, SELECT ON 数据对象名, UPDATE ON 数据对象名, DELETE ON 数据对象名, INSERT ON 数据对象名, ALTER ON 数据对象名 GRANT CONNECT, RESOURCE TO 用户名; GRANT SELECT ON 表名 TO 用户名; GRANT SELECT, INSERT, DELETE ON表名 TO 用户名1, 用户名2; 2.REVOKE 回收权限 REVOKE CONNECT, RESOURCE FROM 用户名; REVOKE SELECT ON 表名 FROM 用户名; REVOKE SELECT, INSERT, DELETE ON表名 FROM 用户名1, 用户名2; 子查询(SUBQUERY)是指嵌入在其他SQL语句中的一个查询。 子查询可以嵌套,嵌套子查询的求解次序是由里向外,即先处理子查询,然后将其查询的结果用于其父查询。使用嵌套子查询的方法,可以用一系列简单的查询构成复杂的查询,从而明显增强SQL语句的功能。 注:在SELECT语句和DML(数据库操作语句)语句中的子查询不能使用ORDER BY子句,它只能用在最外面的父查询中。但是在DDL(数据库定义语句)语句中的子查询可以使用ORDER BY 子句。 1、单行子查询 单行子查询只返回一行数据(但父查询可以返回多行)。在WHERE子句中使用单行子查询时,可以使用单行运算符。 示例1:显示工资最高的雇员信息。先利用单行子查询找出最高工资,然后再运行父查询。 SELECT ename,deptno,sal FROM emp WHERE sal = (SELECT MAX(sal) FROM emp); 2、多行子查询 多行子查询可以返回多行数据。在WHERE子句中使用多行子查询时,必须使用多行运算符(IN、NOT IN、EXISTS、NOT EXISTS、ALL、ANY)。如果不能确认子查询会返回多少行,则在子查询中使用多行运算符比使用单行运算符更安全、否则容易失败。 示例2:显示与部门编号为20的岗位相同的雇员信息。 SELECT * FROM emp WHERE job IN (SELECT distinct job FROM emp WHERE deptno = 20); 示例3:显示高于部门编号为20的所有雇员的工资的雇员信息。 SELECT * FROM emp WHERE sal > all(SELECT sal FROM emp WHERE deptno = 20); 示例4:显示高于部门编号为20的任意雇员的工资的雇员信息。 SELECT * FROM emp WHERE sal > any(SELECT sal FROM emp WHERE deptno = 20); 3、相关子查询 相关子查询是指引用了父查询中某些表或某些列的子查询(但父查询不能引用子查询中的表或列)。 示例5:显示每个部门最高工资的雇员编号、雇员姓名、职位、部门号和工资。 SELECT empno,ename,job,deptno,sal FROM emp a WHERE sal = (SELECT max(sal) FROM emp b WHERE a.deptno = b.deptno ) ORDER BY a.deptno; 示例6:显示工作在NEW YORK的雇员信息。 select * from emp e where exists (select * from dept d where e.deptno = d.deptno and d.loc = 'NEW YORK') 4、标量子查询 标量子查询只返回单行单列数据。标量子查询可以用在大多数使用一个列名或者表达式的地方。如作为一个参数用在一个单行函数、INSERT语句的VALUES子句、ORDER BY 子句、WHERE 子句、SELECT的选择列中。但不能用在GROUP BY子句和HAVING子句中。 示例7:显示每个部门的编号及这个部门的最高工资,并按照最高工资升序排序。 SELECT DISTINCT deptno,(SELECT MAX(sal) FROM emp b WHERE b.deptno = a.deptno) maxsal FROM emp a ORDER BY maxsal 5、多列子查询 单行子查询和多行子查询都是返回单列数据。而多列子查询是指返回多列数据的子查询。多列子查询一般用于比较多个列的数据,即可以成对比较(要求比较的多个列的数据必须同时匹配)。 示例8:显示与SMITH部门和岗位完全相同的所有雇员的信息。用成对比较的方式。 SELECT ename,deptno,sal,job FROM emp WHERE (deptno,job) = (SELECT deptno,job FROM emp WHERE ename = 'SMITH') 五、集合查询(UNION|UNION ALL) SELECT empno,ename,mgr FROM emp WHERE deptno = 30 UNION ALL SELECT empno,ename,mgr FROM emp WHERE job = 'MANAGER'; 六、交叉查询(INTERSECT) INTERSECT运算符用于获得两个结果集合的交集,只会显示同时存在于两个结果集合中的数据,并且会以第一列的结果进行排序。 SELECT empno,ename,mgr FROM emp WHERE deptno = 30 INTERSECT SELECT empno,ename,mgr FROM emp WHERE job = 'MANAGER'; 七、差查询(MINUS) MINUS运算符用于获得两个结果集合的差集,只会显示在第一个结果集中存在、但在第二个结果集中不存在的数据,并且会以第一列的结果进行排序。 SELECT empno,ename,mgr FROM emp WHERE deptno = 30 MINUS SELECT empno,ename,mgr FROM emp WHERE job = 'MANAGER'; 一、笛卡儿连接 SELECT * FROM dept d,emp e WHERE d.deptno=20; 二、相等连接 示例:显示在部门编号为20工作的雇员名称、工资及其部门名称。 SELECT d.deptno,d.dname,e.ename,e.sal FROM dept d,emp e WHERE d.deptno = e.deptno AND d.deptno = 20; 三、不等连接 示例:找出在部门编号为30工作的雇员的工资等级。 SELECT e.ename,e.sal,s.grade FROM emp e,salgrade s WHERE e.sal BETWEEN s.losal AND s.hisal AND a.deptno = 30; 四、自连接 示例:查询显示了emp表中在部门编号为30工作的雇员的名字及其上级的名字。 SELECT e.ename ,m.ename FROM emp e,emp m WHERE m.empno = e.mgr AND e.deptno = 30; 1、显示所有玩具的基本信息列表;(Toyz) select * from Toyz; 2、显示所有购物者的信息列表;(Shopper) select * from Shopper||select Shopper from Toyz; 3、显示所有购物者的名字和电子邮件; select vFirstName,vEmailId from Shopper; 7、显示所有住在“加利福利亚州的购物者的名字”; select vFirstName from Shopper where vAddress="加利福利亚州"; 9、列出总金额超过75的订单信息 select *from OrderDetail where mToyCost>75; 11、列出2001年5月22日的订单 select *from Orders where dOrderDate='2001年5月22日'; 12、列出价格在15到20之间的所有玩具的列表(要求两种方式求解) select *from Toys where mToyPrice between 15 and 20; 13、列出属于加利福利亚州和俄亥俄州的购物者的名字和邮件地址(要求两种方式求解) select vFirstName,vAddress where cCountryId in ('加利福利亚州','俄亥俄州'); select vFirstName,vAddress where cCountryId='加利福利亚州',cCountryId='俄亥俄州'; 15、列出没有附加消息的订单资料 select *from OrderDetail where vMessage is null; 16、显示所有玩具的名字和价格,保证最贵的玩具总在列表的最前面 select *from Toyz where vToyName,order by mToyPrice number Desc; 19、显示价格低于20的玩具的名字和价格,并以价格的升序排列 select vToyzName from Toyz where mToyPrice number >20 order by mToyPrice number ; 23、统计玩具的最大、最小和平均价格 select Max(mToyPrice),Min(mToyPrice),Avg(mToyPrice)*from Toys; 24、统计所有订单合起来的总价格 select count(mTotalCost) from Orders; 25、根据2000年的玩具销售总数,显示前五名玩具的ID select *from PickOfMonth where iYear='2000',rownum<5; 28、显示玩具名中有“娃娃”字样的所有玩具的资料 select vToyName from Toys where vToyName like'%娃娃%'; 示例5:查询1983年1月1日之后雇佣的雇员 select *from emp where HIREDATE>'01-1月-1983'; 示例6:查询在部门编号为20工作的、工资高于2500元或岗位是CLERK的所有雇员的信息。 select *from emp where deptno=20 and sal>2000 or JOB='CLERK'; 示例7:查询工资在2500~3500元之间的,1981年出生的没有领到补助的所有雇员的信息。 select *from emp where sal between 2500 and 3500 and HIREDATE like '%81' and comm is null; 示例8:查询姓名的首字符为A或第二个字符为A的所有雇员的信息。 select *from emp where ENAME like 'A%' or ENAME like '_A%'; 示例11:以部门编号降序及姓名升序来查询工资在1500~3000元的雇员信息。 select *from emp where sal between 1500 and 3000 order by empno desc,ename asc; 示例13:显示每个部门的平均工资和最高工资。 select Max(sal), Avg(SAL) FROM EMP GROUP BY DEPTNO; 示例14:显示每个部门、每种岗位的平均工资和最高工资。 select Max(sal), Avg(SAL) FROM EMP GROUP BY DEPTNO,JOB; 示例15:显示平均工资高于2000元的部门编号、平均工资和最高工资。 select * from emp where sal>(select avg(sal) from emp); select * from emp a where sal>(select avg(sal) from emp b where a.job=b.job); select * from emp a where a.deptno=(select d.deptno from dept d where lower(d.loc)='dallas'); update emp e set sal=sal*2 where e.deptno=(select d.deptno from dept d where lower(d.dname)='sales'); select * from emp a where a.sal>(select max(b.sal) from emp b where b.job=any(select c.job from emp c where lower(c.job)='manager' )); select * from emp a where sal=(select max(sal) from emp b where a.deptno=b.deptno); select * from emp a where sal=(select max(sal) from emp b where a.deptno=b.deptno) order by sal; 1.增加主键 alter table TABLE_NAME add constraint KEY_NAME primary key (TABLE_COLUMN); 指定表空间 alter table TABLE_NAME add constraint KEY_NAME primary key (TABLE_COLUMN) using index tablespace TABLE_SPACE_NAME; 2.增加外键 alter table TABLE_NAME add constraint FK_NAME foreign key (TABLE_COLUMN) references KEY_TABLE_NAME; 3.使主键或外键失效、生效 alter table TABLE_NAME disable(enable) constraint KEY_NAME; 4、查看各种约束 select constraint_name,table_name,constraint_type,status from user_constraints; select constraint_name, constraint_type,search_condition, r_constraint_name from user_constraints where table_name = upper('&table_name') select c.constraint_name,c.constraint_type,cc.column_name from user_constraints c,user_cons_columns cc where c.owner = upper('&table_owner') and c.table_name = upper('&table_name') and c.owner = cc.owner and c.constraint_name = cc.constraint_name order by cc.position; 5、删除主键或外键 alter table TABLE_NAME drop constraint KEY_NAME; 6、建外键 单字段时:create table 表名 (col1 char(8), cno char(4) REFERENCE course); 多个字段时,在最后加上 Foreign Key (字段名) REFERENCE 表名(字段) 连带删除选项 (on delete cascade 当指定时,如果父表中的记录被删除,则依赖于父表的记录也被删除 REFERENCE 表名() on delete cascade; 7、删除带约束的表 Drop table 表名 cascade constraints; 8:索引管理 <1>.creating function-based indexes sql> create index summit.item_quantity on summit.item(quantity-quantity_shipped); <2>.create a B-tree index sql> create [unique] index index_name on table_name(column,.. asc/desc) tablespace sql> tablespace_name [pctfree integer] [initrans integer] [maxtrans integer] sql> [logging | nologging] [nosort] storage(initial 200k next 200k pctincrease 0 sql> maxextents 50); <3>.pctfree(index)=(maximum number of rows-initial number of rows)*100/maximum number of rows <4>.creating reverse key indexes sql> create unique index xay_id on xay(a) reverse pctfree 30 storage(initial 200k sql> next 200k pctincrease 0 maxextents 50) tablespace indx; <5>.create bitmap index sql> create bitmap index xay_id on xay(a) pctfree 30 storage( initial 200k next 200k sql> pctincrease 0 maxextents 50) tablespace indx; <6>.change storage parameter of index sql> alter index xay_id storage (next 400k maxextents 100); 7.allocating index space sql> alter index xay_id allocate extent(size 200k datafile 'c:/oracle/index.dbf'); <8>.alter index xay_id deallocate unused; <9>、查看索引 SQL>select index_name,index_type,table_name from user_indexes order by table_name; <10>、查看索引被索引的字段 SQL>select * from user_ind_columns where index_name=upper('&index_name'); 11、创建序列 select * from user_sequences; create sequence SEQ_NAME start with 1000 maxvalue 1000 increment by 1; alter sequence SEQ_NAME minvalue 50 maxvalue 100; 12、删除重复行 update a set aa=null where aa is not null; delete from a where rowid!=(select max(rowid) from a b where a.aa=b.aa); 13、删除同其他表相同的行 delete from a where exits (select 'X' from b where b.no=a.no); 或 delete from a where no in (select no from b); 14、查询从多少行到多少行的记录(可以用在web开发中的分页显示) select * from ( select rownum row_id,b.* from (select a.* from sys_oper a) b ) where row_id between 15 and 20 15、对公共授予访问权 grant select on 表名 to public; create public synonym 同义词名 for 表名; 16、填加注释 comment on table 表名 is '注释'; comment on column 表名.列名 is '注释'; 17、分布式数据库,创建数据库链路 create [public] database link LINKNAME [connect to USERNAME identified by PASSWORD] [using 'CONNECT_STRING'] 可以在服务器端,也可以在客户端建立,但必须注意,两台服务器之间 数据库必须可以互访,必须各有各自的别名数据库 18、查看数据库链路 select * from all_db_links; select * from user_db_links; 查询 select * from TABLENAME@DBLNKNAME; 创建远程数据库同义词 create synonym for TABLENAME@DBLNKNAME; 操纵远程数据库记录 insert into TABLENAME@DBLNKNAME (a,b) values (va,vb); update TABLENAME@DBLNKNAME set a='this'; delete from TABLENAME@DBLNKNAME; 怎样执行远程的内嵌过程 begin otherdbpro@to_html(参数); end; 19、数据库链路用户密码有特殊字符的时候,可以用双引号把密码引起来 create public database link dblink1 connect to db1 identified by "123*456" using 'db11' 20.oracle8中扩充了group by rollup和cube的操作。有时候省了你好多功夫的。 <1>下面的语句可以进行总计 select region_code,count(*) from aicbs.acc_woff_notify group by rollup(region_code); <2> 对第1个字段小计,最后合计 select region_code,write_status,count(*) from aicbs.acc_woff_notify group by rollup(region_code,write_status); ---------------------- 570 0 3 570 1 2 570 5 --此处小计了570的记录 571 0 10 571 1 2 571 12 --此处小计了571的记录 ..... 100 --此处有总计 <3> 复合rollup表达式,只做总计 select region_code,write_status,count(*) from aicbs.acc_woff_notify group by rollup(region_code,write_status); <4> 对第1个字段小计,再对第2个字段小计,最后合计 select region_code,write_status,count(*) from aicbs.acc_woff_notify group by cube(region_code,write_status); ---------------------- 100 --此处有总计 0 60 --对write_status=0的小计 1 39 --对write_status=1的小计 3 1 --对write_status=3的小计 570 5 --此处小计了570的记录 570 0 3 570 1 2 571 12 --此处小计了571的记录 571 0 10 571 1 2 .... <3> 复合cube表达式,只做总计 select region_code,write_status,count(*) from aicbs.acc_woff_notify group by cube(region_code,write_status); <4>下面的语句可以按照rollup不同的字段进行小计 select region_code,write_status,count(*) from aicbs.acc_woff_notify group by region_code,rollup(write_status); 21.查询view的创建语句 sql>set long 1000 sql>select * from user_views where view_name='MY_VIEW_NAME'; or sql>select * from all_views where view_name='MY_VIEW_NAME'; 22、去除数据库中特殊字符 <1>.字符串字段中含有"'",如果用来组合sql语句,会造成语句不准确。 比如:replace(f1,'''','') <2>.字符串字段中含有"\t \n",如果用来在c或者c++程序中输出到文件,格式无法保证。 比如:replace(f2,'\t','') <3>.清除换行和回车 比如: replace(f2,chr(13)||chr(10),'') 23、如何在字符串里加回车或者tab键 在sqlplus中执行 sql>select 'UserId=1233111'||chr(10)||'AccId=13431'||chr(9)||'AccId2=11111' from dual; 24、树形查询 create table zj( bm number(8), bmmc varchar2(20), sjbm number(8) ) insert into zj values(1,'aaa',0) insert into zj values(11,'aaa1',1) insert into zj values(12,'aaa2',1) insert into zj values(111,'aaa11',11) insert into zj values(112,'aaa12',11) insert into zj values(113,'aaa13',11) insert into zj values(121,'aaa21',12) insert into zj values(122,'aaa22',12) insert into zj values(123,'aaa23',12) -- select bm,bmmc,sjbm,level from zj start with sjbm=0 connect by prior bm = sjbm 或者 select bm,bmmc,sjbm,level from zj start with sjbm=0 connect by sjbm = prior bm 25、快照 create snapshot SNAPSHOT_NAME [storage (storage parameter)] [tablespace TABLESPACE_NAME]
/
本文档为【Oracle_SQL语法查询】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索