PLSQL指令總結 v1.0

来源:https://www.cnblogs.com/Lemon-i/archive/2018/01/26/8358776.html
-Advertisement-
Play Games

一、基本查詢 (表:emp 列:ename ,depton,sal 、表示換行) 1.查當前用戶 SQL> show user 2.查表結構 SQL> desc emp (emp:表名) --查詢出名稱、類型、是否為空 3.清屏 SQL> host cls 4.設置行寬 SQL> show line ...


一、基本查詢

(表:emp  列:ename ,depton,sal  、表示換行)

1.查當前用戶  SQL> show user

2.查表結構  SQL> desc emp  (emp:表名)  --查詢出名稱、類型、是否為空

3.清屏  SQL> host cls

4.設置行寬  SQL> show linesize 、 set linesize 120     設置列寬  SQL> col ename for a8 、 col sal for 9999

5.包含 null 的表達式都為 null 。

   解決辦法:nvl(a,b)  --如果 a為null 則返回 b;不為空返回 a

   --nvl(a,b,c)  如果 a為null 則返回 b;否則返回 c

6.distinct:去掉重覆記錄  SQL> select distinct depton from emp

7.||:連接符 、concat:連接函數

   SQL> select concat('hello','  world') from emp       --註:select函數後面必須要有from關鍵字

8.偽表:dual

   SQL> select 'hello' || '  world' 字元串 from dual 、 SQL> select ename||'的薪水是'||sal 信息 from emp

 

二、過濾,排序

1.註意:字元串的大小寫嚴格區分、日期格式敏感 如  DD-MON-RR:'17-11月-81'

2.修改日期格式  SQL > alter session set NLS_DATE_FORMAT='yyyy-mm-dd'  --修改格式為2017-11-81

3.設置區間:between and  --小值在前大值在後

4.在設置集合中:in    SQL> select * from emp where deptno in (10,20)     

   --對應的,不在就是 not in    另外,如果及合作含有 null 則不能使用 not in 僅可使用 in

   SQL> select * from emp where deptno in (10,20,null)

5.模糊查詢

   查詢名字以 S 開頭的員工    SQL> select * from emp where ename like 'S%'    --'%’表示n個字元

   查詢名字是四個字的員工    SQL> select * from emp where ename like '----'    --'_'表示單個字元

   查詢名字中含有下劃線的    SQL> select * from emp where wname like '%\_%'    --'\'表示轉義字元

6.排序:order by    desc:降序  asc:升序    --by後參數可以直接寫數字,對應select列表中的列

   多列排序  SQL> select * from emp order by deptno desc , sal desc    --desc只作用於它前面的列

   為保證空值在後面可以添加 nulls last    --預設null是最大的值

 

三、函數

1.字元函數    

   1)SQL> select lower('Hello World') 轉小寫,upper('Hello World') 轉大寫,initcap('hello world') 首字母大寫

  2)substr  --取子字元串    SQL> select substr ('hello world',4) 子串 from dual

   3)length/lengthb 字元/位元組 數  SQL> select length('hello world') 字元,lengthb('hello world') 位元組 from dual

   4)instr(a,b)  --在a中查找b    SQL> select instr('hello world','ll') 位置 from dual

   5)lpad/rpad  --左/右 填充    SQL> select lpad('abcd',10,'*')  --在abcd左填充6個*使串達到10位

   6)trim  --去掉前後指定的字元    SQL> select trim('H' from 'Hello WorldH') from dual  --取兩個H中間部分

   7)replace  --不顯示某字元    SQL> select replace('hello world','l','*') from dual    --用*代替 l

2.四捨五入 round 

   SQL> select round(45.926,1) 1,round(45.926,0) 2,round(45.926,-1) 3,round(45.926,-2)

   1--45.9  、2--46  、 3--50 、 4--0

3.當前時間  sysdate    10個月後:add_months(sysdate,10)

4.根據job不同進行不同操作

1) select ename,job,sal,

    case job when 'yuangong' then sal+800

                 when 'jingli' then sal+1000

                 else sal+500

    from emp

2) select ename,job,sal,

         decode(job,'yuangong',sal+800,

                            'jingli',sal+1000,

                            sal+500)

    from emp

5.求和:sum(列名)   求記錄數:count(*/列名)  求平均:avg(列名)

6.having:可以使用多行函數而where不行

   select deptno,avg(sal) from emp group by deptno having deptno=10

 

四、多表聯查

1.外連    SQL> select d.deptno,d.dname,count(e.empno) from emp e,dept d where ~

  左外連會把最後不成立的左表項包含在結果中,右外連則包含右表

2.子查詢

  1)可以在主查詢的 where select having from 後使用子查詢

  2.除top-n問題外一般不在子查詢中排序

 

五、對錶的操作

1.取另表數據創表    SQL> create table emp00 as select * from emp where deptno=20

  SQL> create table empinfo as 

                select e.empno,e.ename,e.sal,d.dname from emp e,dept where e.deptno=d.deptno

2.修改列    SQL> alter table emp modify ename varchar2(40)

   刪除列    SQL> alter table emp drop column photo

   重命名列    SQL> alter table emp rename column tname to username

   重命名錶    SQL> rename text1 to text2

 

六、其它

1.分頁

    SQL> select *

        from (select rownum r,e1.* from (select * from emp order by sal ) e1

            where rownum <= 8 )

         ) where r >= 5


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

-Advertisement-
Play Games
更多相關文章
  • 進入redis目錄下 redis-cli -h IP -p 埠 -a 密碼 flushall ...
  • 用SQL語句添加刪除修改欄位 1.增加欄位 alter table docdsp add dspcode char(200) 2.刪除欄位 ALTER TABLE table_NAME DROP COLUMN column_NAME 3.修改欄位類型 ALTER TABLE table_name A ...
  • 在安裝完Oracle10g和創建完oracle資料庫之後,想用資料庫自帶的用戶scott登錄,看看連接是否成功。 問題: 在cmd命令中,用“sqlplus scott/ tiger”登錄時,老是提示如下信息: ERROR:ORA-28000:賬戶已被鎖定。 解決辦法: 在cmd命令提示符中可直接登 ...
  • Oracle導出導入表(.sql、.dmp文件)兩種方法 方法一:.sql文件的導出與導入 導出步驟 使用PL/SQL Developer登錄你需要備份的資料庫; 選擇工具->導出用戶對象; 在對象列表中選擇需要備份的對象,再選擇一個sql類型的輸出文件,點擊【導出】,這隻是導出數據結構; 選擇工具 ...
  • 運營平臺至少要連三個庫:運營庫,A庫,B庫,並且希望達到針對每個功能請求能夠自動切換到對應的數據源(我最終實現是針對Service的方法級別進行切換的,也可以實現針對每個DAO層的方法進行切換。我們系統的功能是相互之間比較獨立的)。 ...
  • 工具/原料 工具/原料 PLSQL 方法/步驟 1.在PLSQL里,用system/css(orcl系統用戶)登陸,登陸的時候普通用戶登陸選擇normal就可以了 方法/步驟 1.在PLSQL里,用system/css(orcl系統用戶)登陸,登陸的時候普通用戶登陸選擇normal就可以了 2.Or ...
  • 1 ALTER TABLE 'table_name' DROP 'id'; 2 ALTER TABLE 'table_name' ADD 'id' int(11) PRIMARY KEY NOT NULL AUTO_INCREMENT FIRST; ...
  • 前言 最近在嘗試一個日誌系統graylog來收集mysql的慢查詢日誌提,供後續的分析、監控和報警等。測試步驟已經到日誌已成功收集到graylog,測試時需要刷一些慢查詢日誌出來。為了刷比較多的日誌和不對測試環境造成較大的影響,想到了使用mysql的sleep函數結合event來做刷慢日誌。 MyS ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...