oracle 语句 笔记
1、查询某个表有多少列。
select column_name
from user_tab_columns
where table_name = 'DQ_S1';
列出所有的字段名。
2、查询昨天一天24个小时数
select *
from dq_s2
where date_time > trunc(sysdate-1) and date_time <=trunc(sysdate)
order by siteid asc,date_time asc;
3、插入日期型值
insert into employee(empno, ename, hiredate, sal) values(7369,'SMITH', to_date('1980/12/17', 'yyyy/MM/dd'),800)
4、merge into 用法
merge into 既可以更新,也可以插入
1)满足条件时,更新(update);不满足,插入(insert)。
merge into test02 t1
using (select 3 aa from dual) t2
on (t1.aa = t2.aa)
when matched then
update set t1.bb = 6
when not matched then
insert (aa,bb) values (3,6)
表test02 就两列 aa bb
select 3 aa from dual 判断 aa 中是否有3 这个值,并且on (t1.aa = t2.aa) 或多个条件,如果有就update 更新 bb,如果没有就inset插入
merge into zd_sjlr t1 using dual on(t1.C_DATE=to_date('','yyyy-MM-dd') and t1.C_TIME='0:00-12:00' and t1.C_ROAD='CH2')
when matched then update set t1.C_BTIJI=2.1, t1.C_STIJI=6.1 where t1.C_DATE=to_date('','yyyy-MM-dd') and t1.C_TIME='0:00-12:00' and t1.C_ROAD='CH2'
when not matched then insert(t1.C_DATE,t1.C_TIME,t1.C_ROAD,t1.C_BTIJI,t1.C_STIJI) values(to_date('','yyyy-MM-dd'),'0:00-12:00','CH2','2.1','6.1')
批执行
declare
total date:= trunc(sysdate-2) ;
begin
for i_count in 1..10000 LOOP
insert into DQ_DATE(date_time) values ( total );
total := total + 1/24;
end loop;
end;
2)同一张表,不满足条件,插入(insert)数据
merge into dq_report_info t1 using dual on(t1.reportname=?)
when not matched then insert(t1.FID,t1.DUTY_DATE,t1.REPORTNAME,t1.DUTY_NAME,t1.REPORTSRC,t1.REPORTDATE,t1.STATUS1)
values(sys_guid(),?,?,?,?,?,?)
5、原始数据时序图
连接两列的字符串:t1.siteid||'-'||t2.sitename
select t2.sitename,t1.*,t1.siteid||'-'||t2.sitename siteall from
(select tb1.*,case when tb2.FID is not null then '有数' else '无数' end status from
(select SITEID,DATE_TIME - interval '' hour starttime,DATE_TIME endtime from (select DATE_TIME from DQ_DATE where DATE_TIME > sysdate -interval '' hour and DATE_TIME < sysdate),(select distinct siteid siteid from DQ_S2 where DATE_TIME > sysdate-7) order by siteid desc,DATE_TIME) tb1
left join DQ_S2 tb2 on tb1.siteid=tb2.siteid and tb1.endtime = tb2.DATE_TIME) t1
left join DQ_ZDXXB t2 on t1.siteid = t2.siteid
6、合并多条数据为一条数据
用wm_concat() 函数 数据<4000条
SELECT wm_concat (t2.sitename) sitename
FROM (SELECT *
FROM DQ_T_V8_MV
WHERE siteid IN (3,5,11,18,9,10,19,20,8,28,7,37)
AND all_level = 1) t1
LEFT JOIN
DQ_ZDXXB t2
ON t1.siteid = t2.siteid
WHERE t1.day_time = TRUNC (SYSDATE - 1);
7、联合主键
CREATE TABLE DQ_QK_C
(
C_DATE DATE,
C_CONTENT VARCHAR2 (10),
C_RESULT VARCHAR2 (5),
C_PROCESS VARCHAR2 (50),
CONSTRAINT PK_TAB PRIMARY KEY (C_DATE, C_CONTENT)/*联合主键*/
);
8、修改添加字段
alter table tableName modify(colName varchar2(25));
alter table table_name add (col1 type,col2 type);
9、复制表结构、数据
--1. 复制表结构及其数据: create table table_name_new as select * from table_name_old --2. 只复制表结构: create table table_name_new as select * from table_name_old where 1=2; --或者: create table table_name_new like table_name_old --3. 只复制表数据: --如果两个表结构一样: insert into table_name_new select * from table_name_old --如果两个表结构不一样: insert into table_name_new(column1,column2...) select column1,column2... from table_name_old pasting
10、insert into Table as Select
insert into table a select * from table b
11、把A用户的t1授权给B用户
grant select on t1 to B
oracle 语句 笔记的更多相关文章
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- ORACLE存储过程笔记1
ORACLE存储过程笔记1 一.基本语法(以及与informix的比较) create [or replace] procedure procedure_name (varible {IN|OUT ...
- oracle学习笔记第一天
oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字 1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...
- Oracle学习笔记之四,SQL语言入门
1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...
- Oracle学习笔记—数据字典和常用命令(转载)
转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...
- 吴裕雄--天生自然 oracle学习笔记:oracle理论学习详解及各种简单操作例子
1. 数据库的发展过程 层次模型 -->网状模型 -->关系模型 -->对象关系模型 2. 关于数据库的概念 DB:数据库(存储信息的仓库) DBMS:数据库管理系统(用于管理数据库 ...
- [转载]T-SQL(Oracle)语句查询执行顺序
原文链接:http://blog.sina.com.cn/s/blog_61c006ea0100mlgq.html sql语法的分析是从右到左,where子句中的条件书写顺序,基本上对sql性能没有影 ...
- 性能测试常用Oracle语句
性能测试常用Oracle语句 显示数据库当前的连接数 select count(*) from v$process; 显示数据库最大连接数: select value from v$parameter ...
- oracle语句随笔
oracle语句随笔 dmp数据的导入. ; --创建用户 GRANT CONNECT,RESOURCE,DBA TO memsspc; --赋值权限 --cmd 中导入命令 IMP memsspc@ ...
随机推荐
- concurrent.futures- 启动并行任务
python因为其全局解释器锁GIL而无法通过线程实现真正的平行计算.这个论断我们不展开,但是有个概念我们要说明,IO密集型 vs. 计算密集型. IO密集型:读取文件,读取网络套接字频繁. 计算密集 ...
- QML C++插件dll引用
插件的创建非常简单,但是它可以复用,并且为不同的应用程序扩展类型.使用创建的插件是非常灵活的解决方案.关于插件一个很好的例子见QmlBook-In-Chinese 中最后一章介绍的例子. 本文主要备忘 ...
- centos7.2环境nginx+mysql+php-fpm+svn配置walle自动化部署系统详解
centos7.2环境nginx+mysql+php-fpm+svn配置walle自动化部署系统详解 操作系统:centos 7.2 x86_64 安装walle系统服务端 1.以下安装,均在宿主机( ...
- 解决Idea运行testng套件无testoutput文件夹问题
说明:testNG的工程我是使用eclipse创建的,直接导入到idea中,运行test时不会生产test-output,只能在idea的控制台中查看运行结果,然后到处报告,经过不懈的百度终于找到怎么 ...
- robotium之webview元素处理
今天写robotium脚本发现,用uiautomatorviewer定位百度贴吧的登录框是无法定位的,如图: 明显无法定位用户名.密码输入框,无法定位元素那就无法对控件无法操作 如何定位webview ...
- js子节点children和childnodes的用法(非原创)
想要获取子节点的数量,有几种办法. childNodes 它会把空的文本节点当成节点, <ul> 文本节点 <li>元素节点</li> 文本节点 <li> ...
- JNI和NDK
作者:十岁的小男孩 QQ:929994365 心之安处即是吾乡 前言 本文试图通过解答以下三个问题来达到学习JNI和NDK的目的.是什么?有什么用?怎么用?文章内容前三节来自下面第一个链接的博主共享, ...
- PHP实现删除字符串中任何字符的函数
function delStr($start, $end, $orgenStr) { //读取要删除字符位置的前一部分字符串,并赋值给$temp //strpos读取字符第一次出现的位置 //subs ...
- WebService简介-02
WebService-面向服务编程SOA WebService-远程通信 运行效果: 1:添加服务器引用http://www.webxml.com.cn/WebServices/WeatherWebS ...
- 2017-2018-2 20155309南皓芯 Exp6 信息搜集与漏洞扫描
实践内容 1.各种搜索技巧的应用 2.DNS IP注册信息的查询 3.基本的扫描技术:主机发现.端口扫描.OS及服务版本探测.具体服务的查点 4.漏洞扫描:会扫,会看报告,会查漏洞说明,会修补漏洞 基 ...