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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...