Oracle常用的SQL方法總結

来源:http://www.cnblogs.com/pengze0902/archive/2016/10/18/5974873.html
-Advertisement-
Play Games

在項目中一般需要對一些數據進行處理,以下提供一些基本的SQL語句: 1.基於條件的插入和修改:需要在表中插入一條記錄,插入前根據key標識判斷。如果標識符不存在,則插入新紀錄,如果標識符存在,則根據語句中所給的新值對原紀錄中的欄位進行更新: 2.在分組和集合里統計分組:當需要統計一個分組裡的成員,或 ...


   在項目中一般需要對一些數據進行處理,以下提供一些基本的SQL語句:   

1.基於條件的插入和修改:需要在表中插入一條記錄,插入前根據key標識判斷。如果標識符不存在,則插入新紀錄,如果標識符存在,則根據語句中所給的新值對原紀錄中的欄位進行更新:

merge into A
using B
on (A.key = B.key)
when matched then
  update set A.name = B.name
when not matched then
  insert into (A.key, A.name) values (B.key, B.name)

2.在分組和集合里統計分組:當需要統計一個分組裡的成員,或有多少個子分組,及其他基於集合的統計。在進行基於集合的統計時,還需要動態包括或剔除滿足特定條件的記錄。

實例如下:基於職工在企業里的升職次數,來統計企業每個員工經歷過的工作崗位次數。

select jh.JobsHeld, count(*) as StaffCount
      from (select u.employee_id, count(*) as JobsHeld
              from (select employee_id
                      from hr.employees
                    union all
                    select employee_id from hr.job_history) u
             group by u.employee_id) jh
     group by jh.JogsHeld

3.根據時間戳恢複數據:

ALTER TABLE tablename ENABLE row movement ;
flashback table tablename to timestamp to_timestamp('2012-09-13 13:00:00','yyyy-mm-dd hh24:mi:ss');

4.有一個類型為字元串的欄位,要講其值遷移到新系統里的數值類型欄位中:

create or replace function isnum(v_in varchar2) return varchar is
  val_err exception;
  pragma exception_init(val_err, -6502) --char to num conv.error
  scrub_num number;
begin
  scrub_num := to_number(v_in) return 'Y';
exception
  when val_err then
    return 'N';
end;

5.解決死鎖問題:

1).查看被鎖的表
  select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;
 
  (2).查看引起死鎖的會話
   select b.username,b.sid,b.serial#,logon_time 
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time;

  (3).殺掉死鎖
alter system kill session ‘sid,serial#’; 

6.查看當前連接用戶正在運行的SQL語句:

select a.SID, a.USERNAME, b.SQL_TEXT
  from v$session a, v$sqltext_with_newlines b
 where a.SQL_ADDRESS = b.ADDRESS
   and a.SQL_HASH_VALUE = b.HASH_VALUE
 order by a.USERNAME, a.SID, b.piece

7.查詢最消耗資源的實時語句:

oracle 11g中,可以通過查詢V$SQL_MONITOR來監控SQL查詢近乎實時的消耗資源
   select * from (
     select a.sid session_id,a.sql_id,a.status,a.cpu_time/1000000 cpu_sec,a.buffer_gets,a.disk_reads,b.sql_text sql_text
     from v$sql_monitor a,v$sql_b
     where a.sql_id=b.sql_id
     order by a.cpu_time desc)
     where rownum<=20;

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 複雜數據類型 Object ECMAScript中的對象其實就是一組數據(屬性)和功能(方法)的集合。 1) 創建Object實例: 1.使用構造函數創建,new Object() var person = new Object(); person.name = "briup"; person ...
  • × 目錄 [1]圓周運動 [2]鐘擺運動 [3]拋物線運動 前面的話 上一篇介紹了變速運動,但只實現了直線運動。如果元素的left和top同時運動,並遵循不同的曲線公式,則會進行不同形式的曲線運動。本文將詳細介紹圓周運動、鐘擺運動和拋物線運動這三種曲線運動形式 圓周運動 圓周運動可能是最好理解的曲線 ...
  • 近段時間在程式中寫到有關搜索的功能。其中有使用到MS SQLServer的關鍵詞BETWEEN,它是搜索數值範圍(包括本身)之間的數據。在使用它時,一些情況還需要註意的。如果時間的數據。搜索時間數據,要看資料庫存儲時間精度,存儲只有日期或帶有時間日期就需要註意了。不然搜索出來的數據與預期有有些出入。 ...
  • MySQL 字元串截取函數:left(), right(), substring(), substring_index()。還有 mid(), substr()。其中,mid(), substr() 等價於 substring() 函數,substring() 的功能非常強大和靈活。 1. 字元串截 ...
  • 前言:真正用到mysql是在公司的第二個項目下,具體的一些在之前的博客文章(http://www.cnblogs.com/zhengzeze/p/5623440.html)中也提到了,其中涉及到,免安裝版的mysql的配置問題,之前是從網上博客中學習的。現在把它貼出來,免得以後找不到了。具體的文章轉 ...
  • 數據作為信息的載體,要分析數據中包含的主要信息,即要分析數據的主要特征(即數據的數字特征), 對於數據的數字特征, 包含數據的集中位置、分散程度和數據分佈,常用統計項目如下: 集中趨勢統計量: 均值(Mean)、中位數(Median)、眾數(Mode)、百分位數 離散趨勢統計量:標準差(sd)、方差 ...
  • 前幾日安裝sql server2008r2 的時候碰到這個問題: 出現以下錯誤: SQL Server 安裝程式在運行 Windows Installer 文件時遇到錯誤。 Windows Installer 錯誤消息: 打開安裝日誌文件的錯誤。請驗證指定的日誌文件位置是否存在,是否可以寫入。 Wi ...
  • 介紹 本篇文章主要介紹在oracle中怎樣使用語句創建用戶,如果你是資料庫運維人員那麼這是必須掌握的,順便提一下在oracle中資料庫的概念它和其它資料庫系統比如mysql和sqlserver不一樣,在oracle中可以將用戶理解成其它的資料庫系統中的資料庫的概念,oracle中只有一個全局資料庫並 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...