常用SQL[ORACLE]
1.常用系统函数 ↑
--decode
decode(column,if_value,value,elseif_value,value,default_value); decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值) 好比一张表: select decode(score,'A','优秀','B','良好','C','及格','不及格') from t_table
--sum
求和函数
--wm_concat
该函数可以把列值以","号分隔起来,并显示成一行
2.常用sql语句 ↑
--新建用户
create user zhaopei identified by zhaopei;
--给用户权限
grant dba to zhaopei ;
--删除表字段
alter table Tbl_Survey_Human_New DROP COLUMN 字段名;
alter table Tbl_Survey_Human_New DROP COLUMN n_oa_report_FLAG;
--新增表字段
alter table Tbl_Survey_Human_New add(字段名 字段类型);
alter table Tbl_Survey_Human_New add(n_protocaryon_report_FLAG varchar2(2));
--修改表字段
alter table Tbl_Survey_Human_New modify(字段名 字段类型);
alter table Tbl_Survey_Human_New modify(c_caseisreal_type varchar2(30));
--添加字段备注
comment on column 表名.字段名 is '注释';
comment on column Tbl_Report_Caseseat.BLOCKED is '派查勘员受阻';
--创建序列
create sequence mysq
minvalue 1 --最小值
maxvalue 99999999999999999 --最大值
start with 1 --开始值
increment by 1 --每次增长值
cache 20; --缓存大小
--Union 并集操作 .
对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
--Union All 并集操作
对两个结果集进行并集操作,包括重复行,不进行排序;
--简单Case函数 CASE sex
WHEN '' THEN '男'
WHEN '' THEN '女'
ELSE '其他' END --Case搜索函数 CASE
WHEN sex = '' THEN '男'
WHEN sex = '' THEN '女'
ELSE '其他' END
--查询相同条件的其中一条数据
select * from tb k_id in (select min(k_id) from tb group by d_id)
--动态SQL.
--动态sql execute immediate
begin
execute immediate 'select * from scott.emp';
execute immediate 'create table emp1121(id number,name varchar2(10),salary number )';
end;
--异常处理1
declare
num1 number := 1;
num2 number := 0;
my_exce exception; --定义错误类型
begin
if num2 = 0 then
raise my_exce; --自定义错误
end if;
num1 := num1 / num2;
exception
when my_exce then --自定义错误处理
dbms_output.put_line(sqlcode || '===' || sqlerrm);
dbms_output.put_line('自定义 错误');
when others then
dbms_output.put_line(sqlcode || '===' || sqlerrm);
dbms_output.put_line('除零错误');
end;
--异常处理2
declare
num1 number := 1;
num2 number := 0;
begin
if num2 = 0 then
raise_application_error(-20991, '部门代码为空'); --自定义异常错误消息
--RAISE_APPLICATION_ERROR(error_number,error_message,[keep_errors] );--keep_errors 为可选
--error_number 是从 –20,000 到 –20,999 之间的参数
--error_message 是相应的提示信息(< 2048 字节)
end if;
num1 := num1 / num2;
exception
when others then
dbms_output.put_line(sqlcode || '===' || sqlerrm);
dbms_output.put_line('除零错误');
end;
3.一些定义和关键字 ↑
--DDL和DML
DDL:如drop,alter,truncate。
DML:如insert,update,delete,merge。
--DECLARE
declare 声明变量
--DEFAULT
default 默认值
--数组类型.
DECLARE
--定义一个最多保存5个VARCHAR(25)数据类型成员的VARRAY数据类型
TYPE REG_VARRAY_TYPE IS VARRAY(5) OF VARCHAR(25);
--声明一个该VARRAY数据类型的变量
V_REG_VARRAY REG_VARRAY_TYPE; BEGIN
--用构造函数语法赋予初值
v_reg_varray := reg_varray_type
('中国', '美国', '英国', '日本', '法国'); DBMS_OUTPUT.PUT_LINE('地区名称:'||v_reg_varray(1)||'、'
||v_reg_varray(2)||'、'
||v_reg_varray(3)||'、'
||v_reg_varray(4));
DBMS_OUTPUT.PUT_LINE('赋予初值NULL的第5个成员的值:'||v_reg_varray(5)||' count:'||v_reg_varray.count);--count可查数组的长度
--用构造函数语法赋予初值后就可以这样对成员赋值
v_reg_varray(5) := '国';
DBMS_OUTPUT.PUT_LINE('第5个成员的值:'||v_reg_varray(5));
END;
--记录类型
declare
type test_type is record(
name varchar2(10) not null := 'zhangsan',
id varchar2(10));
test_v test_type;
begin
test_v.name := '李四';
test_v.id := '';
dbms_output.put_line(test_v.name || ' ' || test_v.id);
end;
4.需要注意的 ↑
存储过程中is和as的区别
在存储过程(PROCEDURE)和函数(FUNCTION)中没有区别,在视图(VIEW)中只能用AS不能用IS,在游标(CURSOR)中只能用IS不能用AS。
赋值
str1 := 'str'; --数据库中的赋值 是 :=
比较
str1=str2 --数据库中的比较符 是单等号
LENGTH,LENGTHB,LENGTHC,LENGTH2,LENGTH4的区别
LENGTH(string1) 返回以字符为单位的长度.
LENGTHB(string1) 返回以字节为单位的长度.
LENGTHC(string1) 返回以Unicode完全字符为单位的长度.
LENGTH2(string1) 返回以UCS2代码点为单位的长度.
LENGTH4(string1) 返回以UCS4代码点为单位的长度.
oracle中 substrb() substrc() substr2() substr4()的区别
substr 按字符截取,单位字符
substrb 按字节,单位字节
substrc unicode字符为单位
substr2 ucs2代码点为单位
substr4 ucs4代码点为单位 substr是按字符来计算,一个字母或汉字都按一个字符计算如:
substr('智能ABC',2,2)='能A'
如果想要按字节来计算则可以采用substrb函数,用法一样
substrb('智能ABC',3,4)='能AB' 当然还有另外几个按不同编码计算的函数
substrc:按Unicode编码,
substr2:按UCS2编码,
substr4:按UCS4编码。
常用SQL[ORACLE]的更多相关文章
- oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数
花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...
- Oracle常用SQL查询(2)
三.查看数据库的SQL 1 .查看表空间的名称及大小 select t.tablespace_name, round ( sum (bytes / ( 1024 * 1024 )), 0 ) ts ...
- Oracle常用SQL查询
一.ORACLE的启动和关闭 1.在单机环境下要想启动或关闭oracle系统必须首先切换到oracle用户,如下: su - oracle a.启动Oracle系统 oracle>svrmgrl ...
- oracle sqlplus及常用sql语句
常用sql语句 有需求才有动力 http://blog.csdn.net/yitian20000/article/details/6256716 常用sql语句 创建表空间:create tables ...
- ORACLE 常用SQL查询
一.ORACLE的启动和关闭 1 .在单机环境下 要想启动或关闭ORACLE系统必须首先切换到ORACLE用户,如下 su - oracle a.启动ORACLE系统 oracle > sv ...
- [sql server、oracle] 分组取最大值最小值常用sql
sqlserver2005前: --分组取最大最小常用sql--测试环境if OBJECT_ID('tb') is not null drop table tb;gocreate table tb( ...
- oracle常用SQL语句(汇总版)
Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...
- Oracle EBS DBA常用SQL - 安装/补丁【Z】
Oracle EBS DBA常用SQL - 安装/补丁 检查应用补丁有没有安装:select bug_number,last_update_date from ad_bugs where bug_nu ...
- oracle 常用sql语句
oracle 常用sql语句 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_sizefrom d ...
随机推荐
- IIS与Apache共用80端口
Windows server 2003服务器上安装有默认 IIS 6和Apache两个服务器,IIS运行的一个.net程序,apache运行php程序,现在想让它们同时都能通过80端口访问,设置起来还 ...
- 用WinForm写的员工考勤项目!!!!!!
先说几句,作为一个还在学习的程序员,掌握的知识有限:但我利用自身所学,给一些像我一样还在学习的码农提供我的绵薄之力! 写的不好,但是尽力了,希望大牛指点.多多吐槽!!! 好了开始说项目需求: 实现新增 ...
- Python 学习第十七天 jQuery
一,jQuery 知识详解 利用jquery 查找元素,操作元素 1,jquery 引入 <!DOCTYPE html> <html lang="en"> ...
- Makefile笔记之二------make的递归执行
1.make的递归过程指的是: 在Makefile中使用"make"作为一个命令来执行本身或者其它makefile文件的过程. 2.递归的意义: 当前目录下存在一个"su ...
- linux 负载均衡
[博文推荐]关于负载均衡技术使用的一些误区 如今,负载均衡已经不是一个新鲜的词,也不是什么新技术,主要用于解决单机负载能力的局限性,但问题是你的应用真的到了单 机的负载上限了吗,未必,很多不知道如何推 ...
- mysql优化
一.优化事项 1. 数据库(表)设计合理 (不合理设计导致内伤) 我们的表设计要符合3NF 3范式(规范的模式) , 有时我们需要适当的逆范式.2. sql语句的优化(索引,常用小技巧 ...
- Python学习日志(二)
在网易云课堂看到小甲鱼的python视频,想起以前看就是看他的视频学C的虽然后来不了了之都怪我自己啦,于是决定跟着这个视频来学python啦! IDLE IDLE其实是一个python shell , ...
- Delphi之静态方法,虚方法virtual,动态dynamic,抽象abstract,消息
Delphi之静态方法,虚方法virtual,动态dynamic,抽象abstract,消息 http://www.cnblogs.com/zhwx/archive/2012/08/28/266055 ...
- openswan-ipsec.conf配置说明
Name ipsec.conf - IPsec configuration and connections Description The optional ipsec.conf file speci ...
- js排序算法总结——冒泡,快速,选择,插入,希尔,归并
相信排序是任何一个程序猿都会用到的东西,今天简单总结记录下常见的排序算法. 一.冒泡排序 说起冒泡排序,可能每个人都不会陌生,实现思路相当简单明了,就是不停的对数组进行两两比较,将较大(较小)的一项放 ...