oracle sqlplus命令詳解


涉及到的知識要點
a、帶有一個&的替換變量的用法
b、帶有兩個&的替換變量用法
c、define命令用法
d、accept命令用法
e、定制SQL*Plus環境
f、在glogin.sql文件中保存定制結果
g、sqlplus編輯命令


a、帶有一個&的替換變量的用法
1)、使用帶有一個&號的變量值來提示用戶輸入一個值。
eg、
SQL> SELECT     empno, ename, sal, deptno FROM  emp WHERE empno = &empno;
輸入 empno 的值:  7369
原值    1: SELECT empno, ename, sal, deptno FROM  emp WHERE empno = &empno
新值    1: SELECT empno, ename, sal, deptno FROM  emp WHERE empno = 7369

     EMPNO ENAME             SAL     DEPTNO
———- ———- ———- ———-
      7369 SMITH            8888         20

2)、替換變量中的字串和日期值
使用單引號標志替換變量中的日期和字串值。
eg、
SQL> SELECT ename, deptno, sal*12 FROM emp WHERE job='&job';
輸入 job 的值:  ANALYST
原值    1: SELECT ename, deptno, sal*12 FROM emp WHERE job='&job'
新值    1: SELECT ename, deptno, sal*12 FROM emp WHERE job='ANALYST'

ENAME          DEPTNO     SAL*12
———- ———- ———-
SCOTT              20     106656
FORD               20      36000

3)、運行時指定列名、表達式、文本
SELECT empno, ename, job, &column_name
FROM emp
WHERE &condition
ORDER BY &order_column;
輸入 column_name 的值:  sal
原值    1: SELECT empno, ename, job, &column_name
新值    1: SELECT empno, ename, job, sal
輸入 condition 的值:  sal>=3000
原值    3: WHERE &condition
新值    3: WHERE sal>=3000
輸入 order_column 的值:  ename
原值    4: ORDER BY &order_column
新值    4: ORDER BY ename

     EMPNO ENAME      JOB              SAL
———- ———- ——— ———-
      7902 FORD       ANALYST         3000
      7839 KING       PRESIDENT       5000
      7788 SCOTT      ANALYST         8888
      7369 SMITH      CLERK           8888

b、帶有兩個&的替換變量用法
使用帶有兩個&的變量可以使得該變量可以重復使用,而不必在每次使用時提醒用戶輸入。
SQL> SELECT empno, ename, job, &&column_name FROM emp ORDER BY &column_name;
輸入 column_name 的值:  deptno
原值    1: SELECT empno, ename, job, &&column_name FROM emp ORDER BY &column_name
新值    1: SELECT empno, ename, job, deptno FROM emp ORDER BY deptno

     EMPNO ENAME      JOB           DEPTNO
———- ———- ——— ———-
      7782 CLARK      MANAGER           10
      7839 KING       PRESIDENT         10
      7934 MILLER     CLERK             10

c、define命令用法
創建CHAR類型的用戶變量,當定義一個包含空格的變量時,要用單引號將該變量括起來。
eg、
SQL> define deptname = sales
SQL> define deptname; –查看該變量
DEFINE DEPTNAME = "sales" (CHAR)
SQL> SELECT * FROM dept WHERE dname=UPPER('&deptname');
原值    1: SELECT * FROM dept WHERE dname=UPPER('&deptname')
新值    1: SELECT * FROM dept WHERE dname=UPPER('sales')

    DEPTNO DNAME          LOC
———- ————– ————-
        30 SALES          CHICAGO

說明:一個變量將保持在被定義的狀態,直到使用undefine命令將它清除或離開sql*plus。

d、accept命令用法
接收用戶輸入時,創建可定制的用戶提示。
eg、
–提示你輸入一個數值給dept,dept是個變量,可用define命令查看該變量
SQL> accept dept prompt 'Provide the department name: '
Provide the department name: Sales
SQL> define dept; –查看該變量
DEFINE DEPT = "Sales" (CHAR)
SQL> SELECT * FROM dept WHERE dname = UPPER('&dept');
原值    1: SELECT * FROM dept WHERE dname = UPPER('&dept')
新值    1: SELECT * FROM dept WHERE dname = UPPER('Sales')

    DEPTNO DNAME          LOC
———- ————– ————-
        30 SALES          CHICAGO

e、定制SQL*Plus環境
使用SET命令來控制當前的會話。
語法:SET system_variable value
eg、SQL> set arraysize 20;
可以使用SHOW命令來查看set設置。
eg、SQL> show arraysize
arraysize 20
說明: set命令用法具體請看” oracle set命令詳解.txt”

f、在glogin.sql文件中保存定制結果
glogin.sql文件包含在登錄時需要執行的標准SET命令及其他命令,我們可以更改glogin.sql以包含其他SET命令。
如:設置sqlplus環境的linesize為300,並讓這個變量永久生效在$ORACLE_HOME/sqlplus/admin/glogin.sql(D:\dev\oracle\product\10.2.0\db_1\sqlplus\admin)文件中添加如下內容:set linesize 300
a
g、sqlplus編輯命令
1)、執行def命令查看編輯器的設置:
SQL> def

2)、總結下:
l–列sql
n–切換活動行(n代表行數字)
a–活動行后增加(append)
i–活動行后插入新行增加(input)
c–替換(change)
eg、c /emp_name/emp_age/
del n–刪除行n
/–執行sql
eg、
SQL> select deptno, dname from dept;

    DEPTNO DNAME
———- ————–
        10 ACCOUNTING
        20 RESEARCH
        30 SALES
        40 OPERATIONS

SQL> i  where deptno>20
SQL> l
  1  select deptno, dname from dept
  2* where deptno>20
SQL> /

    DEPTNO DNAME
———- ————–
        30 SALES
        40 OPERATIONS

SQL> del 2
SQL> l
  1* select deptno, dname from dept
SQL> a  where deptno>30
  1* select deptno, dname from dept where deptno>30
SQL> l
  1* select deptno, dname from dept where deptno>30
SQL> /

    DEPTNO DNAME
———- ————–
        40 OPERATIONS


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM