真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

一、記錄和集合概述

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),玉山企業(yè)網(wǎng)站建設(shè),玉山品牌網(wǎng)站建設(shè),網(wǎng)站定制,玉山網(wǎng)站建設(shè)報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,玉山網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

         目前為止所介紹的變量的數(shù)據(jù)類型都屬于scalar,即標量,如×××,字符串,日期等等。任何一種編程語言都需要提供一些手段讓用戶創(chuàng)建更復雜的變量,PL/SQL也不例外,本章就來介紹一下PL/SQL中的復合型變量。

 

PL/SQL的復合型變量主要包括兩類:

 

              1. Records:記錄

              2. Collection:集合。Collection又可以分為三種,

                              a. Associative  Array(INDEXTBY table): 關(guān)聯(lián)數(shù)組(或稱索引表,和SQL中的INDEX OF TABLE不是一個概念)

                              b. Nested Table: 嵌套表

                              c. Varray: 可變長度列表。

 

二、記錄和集合的區(qū)別

         Records可以形象的理解為一個容器,用來保存很多其他的數(shù)據(jù)類型,但每種數(shù)據(jù)類型只在記錄中出現(xiàn)一次,例如一個記錄中保存了如下數(shù)據(jù)類型:

 

PL/SQL Record:

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

這個記錄中保存了布爾型、日期型、字符型和BLOB型變量,且每個變量都只出現(xiàn)了一次,每個存放其他數(shù)據(jù)類型的空間稱為域(Field

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

SQL> edit

 

DECLARE

    TYPE myrecord IS RECORD

        (id number(8),

            name varchar2(20)default 'Wilson',

            birthday DATE

        ); 

       

        person myrecord;

BEGIN  

        person.id :=12345;

        person.birthday :=SYSDATE;

       

       DBMS_OUTPUT.PUT_LINE('Name: '|| person.name);

END;   

/

 

SQL> /

Name: Wilson

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

===============================

SQL> edit

 

DECLARE

    person employees%ROWTYPE;

BEGIN

    SELECT * INTO person

    FROM employees WHEREemployee_id = 100;

   

    DBMS_OUTPUT.PUT_LINE('Name: '|| person.first_name);

END;

/

 

SQL> @notes/s37.sql

Name: Steven

 

PL/SQL procedure successfully completed.

===============================================

eg3.

 

SQL> edit

 

DECLARE

    TYPE t_rec IS RECORD

        (v_sal number(8),

         v_minsal number(8)default 1000,

         v_hire_dateemployees.hire_date%TYPE,

         v_reclemployees%ROWTYPE);

    v_myrec t_rec;

BEGIN

    v_myrec.v_sal := v_myrec.v_minsal+ 500;

    v_myrec.v_hire_date :=SYSDATE;

    SELECT * INTO v_myrec.v_recl

    FROM employees WHEREemployee_id = 100;

   DBMS_OUTPUT.PUT_LINE(v_myrec.v_recl.last_name || ' ' ||     TO_CHAR(v_myrec.v_hire_date) || ' '||     TO_CHAR(v_myrec.v_sal));

END;

/

 

SQL> @notes/s38.sql

King 24-AUG-14 1500

 

PL/SQL procedure successfully completed.

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

CREATE TABLE retired_emps (

        EMPNO NUMBER(4),

        ENAME VARCHAR2(25),

        JOB   VARCHAR2(9),

        MGR   NUMBER(4),

        HIREDATE DATE,

        LEAVEDATE DATE,

        SAL   NUMBER(7,2),

        COMM  NUMBER(7,2),

        DEPTNO NUMBER(2)

    );

 

SQL> @notes/s39.sql

 

Table created.

 

SQL> select * from retired_emps where empno = 124;

 

no rows selected

 

SQL> edit

 

DECLARE

    v_employee_number NUMBER :=124;

    v_emp_rec   employees%ROWTYPE;

BEGIN

    SELECT * INTO v_emp_rec FROMemployees

    WHERE employee_id =v_employee_number;

 

    INSERT INTOretired_emps(empno, ename, job, mgr,

                hiredate,leavedate, sal, comm, deptno)

    VALUES( v_emp_rec.employee_id,v_emp_rec.last_name,

            v_emp_rec.job_id,v_emp_rec.manager_id,

            v_emp_rec.hire_date,SYSDATE,

            v_emp_rec.salary,v_emp_rec.commission_pct,

           v_emp_rec.department_id);

    COMMIT;

END;

/

 

SQL> @notes/s40.sql

 

PL/SQL procedure successfully completed.

 

SQL> select * from retired_emps where empno = 124;

 

EMPNO ENAME         JOB              MGR HIREDATE  LEAVEDATE  SAL       COMM    DEPTNO

---------- ----------      --------------- --------- ------------------- ---------      ---------- ---------- ----------

       124 Mourgos     ST_MAN     100    16-NOV-07 24-AUG-14 5800                    50

=========================INSERT============================

SQL> edit

 

DECLARE

    v_employee_number NUMBER := 127;

    v_emp_rec retired_emps%ROWTYPE;

 

BEGIN

    SELECT employee_id, last_name, job_id,manager_id,

    hire_date, hire_date, salary,commission_pct,

    department_id INTO v_emp_rec

    FROM employees

    WHERE employee_id = v_employee_number;

 

    INSERT INTO retired_emps

    VALUES v_emp_rec;

                -- 將查詢結(jié)果打包到v_emp_rec中

END;

/

 

SELECT * FROMretired_emps;

 

SQL>@notes/s41.sql

 

PL/SQL proceduresuccessfully completed.

 

 

     EMPNO ENAME       JOB        MGR   HIREDATE  LEAVEDATE SAL       COMM     DEPTNO

----------------------------------- --------- ---------- --------- --------- -------------------- ----------

       124 Mourgos        ST_MAN 100   16-NOV-07  24-AUG-14  5800        50

       127 Landry           ST_CLERK  120  14-JAN-07  14-JAN-07     3200       50

 

=========================UPDATE============================

 

SQL> edit

 

SET VERIFY OFF

DECLARE

        v_employee_number NUMBER:= 127;

        v_emp_recretired_emps%ROWTYPE;

 

BEGIN

        SELECT *

        INTO v_emp_rec

        FROM retired_emps

        WHERE empno =v_employee_number;

        v_emp_rec.leavedate :=CURRENT_DATE;

 

        UPDATE retired_emps SETROW = v_emp_rec

        WHERE empno = v_employee_number;

END;

/

 

SELECT * FROM retired_emps;

 

 

SQL> @notes/s42.sql

 

PL/SQL procedure successfully completed.

 

 

     EMPNO ENAME     JOB              MGR HIREDATE  LEAVEDATE     SAL       COMM     DEPTNO

     ---------- --------------  ---------- --------- ---------- ------------------    ---------- ---------- ----------

       124 Mourgos      ST_MAN      100 16-NOV-07 24-AUG-14     5800                       50

       127 Landry        ST_CLERK      120 14-JAN-07 24-AUG-14      3200                    50

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS

SQL> edit

 

DECLARE

    myrec employees%ROWTYPE;

BEGIN

    myrec := NULL;

END;

/

 

SQL> @notes/s43.sql

 

PL/SQL procedure successfully completed.


名稱欄目:10.PL_SQL——PL_SQL中的復合數(shù)據(jù)類型之RECORDS
網(wǎng)站路徑:http://weahome.cn/article/peehco.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部