* 요즘은 서블릿(Servlet) 기반으로 작업하는 경우는 드물다.


* JSP는 자바만 알면 쉽게 이해할 수 있는 언어이다.

    - 자바를 많이 공부하자.


* 우리나라 개발자가 알아야 할 기술

  -> Web App

    - Java / C# 기반

    - JSP / ASP(.Net)

    - JavaScript

    - JQuery, Ajax(자바스크립트 라이브러리)

    - HTML5, CSS

    - Mobile : iOS, Android - 요즘은 하이브리드앱도 많이 개발하는 추세

    - 프레임워크

      : Spring MVC(MVC2 패턴) - 요즘은 대부분 MVC2 패턴으로 설계

    - 가장 어려운 부분 중 하나가 환경 설정

      : 처음 이해하는데 개발자를 지치게 하지만, 적응하면 매우 편함

    - XML, JSON

      : 데이터를 전달하는 방식. Parse로 해석

  -> 순수 App

    - Java

  -> IoT

    - C / C++ / Python

    - Sensor Network

    - 아두이노

    - 라즈베리파이

  -> 빅데이터

    - Database

      : DBMS같은 정형화된 데이터가 아닌, 비정형 데이터를 분석, 처리

    - R / Python

    - Hadoop, Spotfire


* 반복문의 종류와 용도

    - for : 시작과 끝이 명확할 때(for-each문의 등장으로 DB select에서도 많이 사용)

    - while : 한 번도 수행하지 않을 수 있다. - DB에서 select할 때

    - do : 최소 한 번은 무조건 수행 - 메뉴 만들 때(최근에는 거의 사용하지 않음)


* 조건문

    - if : 뎁스가 3 이상 넘어가면 if를 잘 쓰지 않고 switch-case를 사용한다.(처리 속도 문제)

    - switch(case) : 조건이 많을 때 사용.


* 이클립스 로딩 속도 빠르게 하기

    - eclipse 디렉토리에서 eclipse.ini 파일을 수정한다.

    - Xms 부분을 수정한다. (256m -> 512m 또는 1024m)

    - 컴퓨터의 메모리 용량이 크면(16G 이상) Xmx도 늘려준다.


* GET / POST의 한글 처리 방식이 약간 다르다.

    - GET은 요청정보 헤더의 URI에 포함되어 전달된다.

    - POST는 요청정보 몸체에 포함되어 전달된다. 몸체에서 setCharacterEncoding() 메소드로 몸체의 데이터들을 인코딩 해주어야 한다.


* 요즘은 URL보다 URI라는 용어를 더 많이 쓴다.

    - URL : Uniform Resource Locator(통합 자원 위치자)

    - URI : Uniform Resource Identifier(통합 자원 식별자)

    - URI는 URL을 포함하는 개념이다.


* Servlet

    - Servlet(Interface) <- Generic Servlet(Abstract Class) <- HttpServlet

* MVC 패턴

  - Model(.java), View(JSP), Controller(Servlet 역할)

  - Request, Response


* 전자정부 프레임워크는 Spring 기반


* 추상 클래스

  - abstract

  - 반드시 재정의(오버라이딩)해서 사용해야 한다.


* 클래스

  - Object Class : 통상적인 클래스

  - Class Instance : 클래스명이 타입이 된다.


* 메모리 영역

  - stack 영역 : class(모양만 가지고 있다), data가 저장되는 곳.

  - heap 영역 : 객체, stack의 데이터를 공유해서 사용. 개비지 컬렉션.


* EJB(Enterprise Java Beans)

  - 메소드에는 관심이 없다.

  - 능력은 굉장히 많다. (다 사용하지는 않는다.)

  - 너무 무겁다.

  - 가볍게 만든 것이 Spring Framework


* Spring

  - EJB의 경량화 버전이라고 이해하면 된다.

  - VO 개념

  - Java EE가 무겁기 때문에 Java SDK + STC(Syntactic Tail Calls) 하면 가볍다.


* 프로젝트 시작하기

  - New - Dynamic Web Project 선택

  - Project명은 소문자로 시작

  - Generate web.xml deployment descriptor 체크하기(default라고 생각하고 체크하자.)

  - 서버에 배포(Deploy) 할 때는 WebContent의 내용만 한다.

  - 서블릿을 생성하려면 New - Servlet 선택

  - 패키지명은 도메인 거꾸로(ciec.co.kr이면 kr 빼고 co.ciec.xxxx)

  - URL Mapping : .jsp 파일을 감싸서 해당 파일이 무엇인지 감춰준다.


* Get / Post 방식

  - form 태그에 속성으로 지정


* 보안 가이드를 준수하자.

  - 자료실 - 기술안내서 가이드

* 개발자가 공부하면 좋은 것

  - 이산수학


* 톰캣 다운로드

tomcat.apache.org

8.5.32 64bit zip

원하는 위치에 압축 해제


* 웹 서버

- Web Server (HTTP)

- WAS Server

 Apache + tomcat

 Web Logic

 WebToB + Jeus : Tmax (국산)


 IIS + .NET

 - MS -> IIS

 - ASP -> .NET

...



* 자바 버전 확인

java -version : 1.8.0_181

javac -version : 1.8.0_172

- 자바는 자동 업데이트 때문에 컴파일러와 버전이 다를 수도 있다.


* 자바 .class 파일을 자바 바이트 코드라고도 한다.

* 라즈베리파이

- OS : 라즈비안

- 굉장히 가볍게 잘 돌아간다.


* 라이센스

- 전략을 가지고 공부하자.

어려운 과목은 미리 포기.

70점 IT-PMP

정보시스템감리사 125분 125문, 1000명 중 상위성적 40명 합격


* Tomcat의 구성

- bin : 실행 파일

- conf : 설정 파일

 server.xml - Tomcat 환경

 web.xml - Site (n개)

 각각의 web의 web.xml - 상위 web.xml을 상속받음



* SVN CVS 형상관리


* Servlet

- servlet과 servlet-mapping은 한 쌍이다.

<servlet>

......

</servlet>


<servlet-mapping>

......

</servlet-mapping>



* 에러

400번대는 해피한 에러, 500번대는 골치아픈 에러

'스마트웹&콘텐츠 개발자 과정 > Servlet | JSP' 카테고리의 다른 글

넷째 시간 끄적끄적  (0) 2018.08.03
세 번째 시간 끄적끄적  (0) 2018.08.02
둘째 시간 끄적끄적  (0) 2018.08.02

[oracle@localhost ~]$ set pagesize 1000

[oracle@localhost ~]$ set long 9

[oracle@localhost ~]$ sqlplus / as sysdba


SQL*Plus: Release 11.2.0.1.0 Production on Mon Jul 30 09:18:11 2018


Copyright (c) 1982, 2009, Oracle.  All rights reserved.


Connected to an idle instance.


SYS> startup

ORACLE instance started.


Total System Global Area  623546368 bytes

Fixed Size                  1338308 bytes

Variable Size             469763132 bytes

Database Buffers          146800640 bytes

Redo Buffers                5644288 bytes

Database mounted.

Database opened.

SYS> conn hr/hr

Connected.

HR> select dbms_metadata.get_ddl('TABLESPACE',tablespace_name)

  2  from dba_tablespaces;

from dba_tablespaces

     *

ERROR at line 2:

ORA-00942: table or view does not exist



HR> conn / as sysdba

Connected.

SYS> 

SYS> select dbms_metadata.get_ddl('TABLESPACE',tablespace_name)

  2  from dba_tablespaces;



DBMS_METADATA.GET_DDL('TABLESPACE',TABLESPACE_NAME)

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


  CREATE TABLESPACE "SYSTEM" DATAFILE

  '/u01/app/oracle/oradata/orcl/system01



  CREATE TABLESPACE "SYSAUX" DATAFILE

  '/u01/app/oracle/oradata/orcl/sysaux01



  CREATE UNDO TABLESPACE "UNDOTBS1" DATAFILE

  '/u01/app/oracle/oradata/orcl/u


DBMS_METADATA.GET_DDL('TABLESPACE',TABLESPACE_NAME)

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



  CREATE TEMPORARY TABLESPACE "TEMP" TEMPFILE

  '/u01/app/oracle/oradata/orcl/



  CREATE TABLESPACE "USERS" DATAFILE

  '/u01/app/oracle/oradata/orcl/users01.d



  CREATE TABLESPACE "NEW_USERS" DATAFILE


DBMS_METADATA.GET_DDL('TABLESPACE',TABLESPACE_NAME)

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

  '/u01/app/oracle/product/11.2.0/db_



  CREATE TABLESPACE "EMP_TBS1" DATAFILE

  '/u01/app/oracle/oradata/orcl/emp_tb



  CREATE TABLESPACE "EMP_TBS2" DATAFILE

  '/u01/app/oracle/oradata/orcl/emp_tb



8 rows selected.


SYS> SYS>  

SYS> 

SYS> 

SYS> select dbms_metadata.get_ddl('TABLE','DEPARTMENTS','HR') from dual;


DBMS_METADATA.GET_DDL('TABLE','DEPARTMENTS','HR')

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


  CREATE TABLE "HR"."DEPARTMENTS"

   (    "DEPARTMENT_ID" NUMBER(4,0),

        "DEPARTM



SYS> !ls

afiedt.buf    ex_07_18.sql  lab_04_03.sql    lab_05_04.sql  lab_08_03.sql    lab2_01_04.sql   m_05_01.sql   m_05_05b.sql    q_dbf.sql        test_hjs_03.sql

Desktop       ex_07_22.sql  lab_05_01_2.sql  lab_06_01.sql  lab2_01_01.sql   lab2_02_01.sql   m_05_02.sql   m_05_06.sql     q_log.sql        test_hjs_04.sql

ex_06_12.sql  ex_07_m.sql   lab_05_01.sql    lab_07_02.sql  lab2_01_02.sql   lab2_02_02.sql   m_05_03.sql   m_07_02.sql     q_tbs.sql        test_hjs_05.sql

ex_06_14.sql  job_pkg.plb   lab_05_02_2.sql  lab_08_01.sql  lab2_01_03.sql   lab2_02_03a.sql  m_05_04.sql   oradiag_oracle  test_hjs_01.sql  test_hjs_06.sql

ex_07_16.sql  job_pkg.sql   lab_05_02.sql    lab_08_02.sql  lab2_01_04b.sql  labs             m_05_05a.sql  over_load.sql   test_hjs_02.sql


SYS> !mkdir directory


SYS> !ls

afiedt.buf    ex_07_16.sql  job_pkg.sql      lab_05_02.sql  lab_08_02.sql   lab2_01_04b.sql  labs         m_05_05a.sql    over_load.sql    test_hjs_02.sql

Desktop       ex_07_18.sql  lab_04_03.sql    lab_05_04.sql  lab_08_03.sql   lab2_01_04.sql   m_05_01.sql  m_05_05b.sql    q_dbf.sql        test_hjs_03.sql

directory     ex_07_22.sql  lab_05_01_2.sql  lab_06_01.sql  lab2_01_01.sql  lab2_02_01.sql   m_05_02.sql  m_05_06.sql     q_log.sql        test_hjs_04.sql

ex_06_12.sql  ex_07_m.sql   lab_05_01.sql    lab_07_02.sql  lab2_01_02.sql  lab2_02_02.sql   m_05_03.sql  m_07_02.sql     q_tbs.sql        test_hjs_05.sql

ex_06_14.sql  job_pkg.plb   lab_05_02_2.sql  lab_08_01.sql  lab2_01_03.sql  lab2_02_03a.sql  m_05_04.sql  oradiag_oracle  test_hjs_01.sql  test_hjs_06.sql


SYS> !

[oracle@localhost ~]$ ls

afiedt.buf    ex_07_16.sql  job_pkg.sql      lab_05_02.sql  lab_08_02.sql   lab2_01_04b.sql  labs         m_05_05a.sql    over_load.sql    test_hjs_02.sql

Desktop       ex_07_18.sql  lab_04_03.sql    lab_05_04.sql  lab_08_03.sql   lab2_01_04.sql   m_05_01.sql  m_05_05b.sql    q_dbf.sql        test_hjs_03.sql

directory     ex_07_22.sql  lab_05_01_2.sql  lab_06_01.sql  lab2_01_01.sql  lab2_02_01.sql   m_05_02.sql  m_05_06.sql     q_log.sql        test_hjs_04.sql

ex_06_12.sql  ex_07_m.sql   lab_05_01.sql    lab_07_02.sql  lab2_01_02.sql  lab2_02_02.sql   m_05_03.sql  m_07_02.sql     q_tbs.sql        test_hjs_05.sql

ex_06_14.sql  job_pkg.plb   lab_05_02_2.sql  lab_08_01.sql  lab2_01_03.sql  lab2_02_03a.sql  m_05_04.sql  oradiag_oracle  test_hjs_01.sql  test_hjs_06.sql

[oracle@localhost ~]$ rm -rf directory/

[oracle@localhost ~]$ ls

afiedt.buf    ex_07_18.sql  lab_04_03.sql    lab_05_04.sql  lab_08_03.sql    lab2_01_04.sql   m_05_01.sql   m_05_05b.sql    q_dbf.sql        test_hjs_03.sql

Desktop       ex_07_22.sql  lab_05_01_2.sql  lab_06_01.sql  lab2_01_01.sql   lab2_02_01.sql   m_05_02.sql   m_05_06.sql     q_log.sql        test_hjs_04.sql

ex_06_12.sql  ex_07_m.sql   lab_05_01.sql    lab_07_02.sql  lab2_01_02.sql   lab2_02_02.sql   m_05_03.sql   m_07_02.sql     q_tbs.sql        test_hjs_05.sql

ex_06_14.sql  job_pkg.plb   lab_05_02_2.sql  lab_08_01.sql  lab2_01_03.sql   lab2_02_03a.sql  m_05_04.sql   oradiag_oracle  test_hjs_01.sql  test_hjs_06.sql

ex_07_16.sql  job_pkg.sql   lab_05_02.sql    lab_08_02.sql  lab2_01_04b.sql  labs             m_05_05a.sql  over_load.sql   test_hjs_02.sql

[oracle@localhost ~]$ mkdir reports_dir

[oracle@localhost ~]$ exit

exit


SYS> create directory reports_dir as '/home/oracle/reports_dir';


Directory created.


SYS> !ls /home/oracle/reports_dir


SYS> desc utl_file

PROCEDURE FCLOSE

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN/OUT

   ID                           BINARY_INTEGER          IN/OUT

   DATATYPE                     BINARY_INTEGER          IN/OUT

   BYTE_MODE                    BOOLEAN                 IN/OUT

PROCEDURE FCLOSE_ALL

PROCEDURE FCOPY

 Argument Name                  Type                    In/Out Default?

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

 SRC_LOCATION                   VARCHAR2                IN

 SRC_FILENAME                   VARCHAR2                IN

 DEST_LOCATION                  VARCHAR2                IN

 DEST_FILENAME                  VARCHAR2                IN

 START_LINE                     BINARY_INTEGER          IN     DEFAULT

 END_LINE                       BINARY_INTEGER          IN     DEFAULT

PROCEDURE FFLUSH

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

PROCEDURE FGETATTR

 Argument Name                  Type                    In/Out Default?

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

 LOCATION                       VARCHAR2                IN

 FILENAME                       VARCHAR2                IN

 FEXISTS                        BOOLEAN                 OUT

 FILE_LENGTH                    NUMBER                  OUT

 BLOCK_SIZE                     BINARY_INTEGER          OUT

FUNCTION FGETPOS RETURNS BINARY_INTEGER

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

FUNCTION FOPEN RETURNS RECORD

 Argument Name                  Type                    In/Out Default?

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

   ID                           BINARY_INTEGER          OUT

   DATATYPE                     BINARY_INTEGER          OUT

   BYTE_MODE                    BOOLEAN                 OUT

 LOCATION                       VARCHAR2                IN

 FILENAME                       VARCHAR2                IN

 OPEN_MODE                      VARCHAR2                IN

 MAX_LINESIZE                   BINARY_INTEGER          IN     DEFAULT

FUNCTION FOPEN_NCHAR RETURNS RECORD

 Argument Name                  Type                    In/Out Default?

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

   ID                           BINARY_INTEGER          OUT

   DATATYPE                     BINARY_INTEGER          OUT

   BYTE_MODE                    BOOLEAN                 OUT

 LOCATION                       VARCHAR2                IN

 FILENAME                       VARCHAR2                IN

 OPEN_MODE                      VARCHAR2                IN

 MAX_LINESIZE                   BINARY_INTEGER          IN     DEFAULT

PROCEDURE FREMOVE

 Argument Name                  Type                    In/Out Default?

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

 LOCATION                       VARCHAR2                IN

 FILENAME                       VARCHAR2                IN

PROCEDURE FRENAME

 Argument Name                  Type                    In/Out Default?

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

 SRC_LOCATION                   VARCHAR2                IN

 SRC_FILENAME                   VARCHAR2                IN

 DEST_LOCATION                  VARCHAR2                IN

 DEST_FILENAME                  VARCHAR2                IN

 OVERWRITE                      BOOLEAN                 IN     DEFAULT

PROCEDURE FSEEK

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN/OUT

   ID                           BINARY_INTEGER          IN/OUT

   DATATYPE                     BINARY_INTEGER          IN/OUT

   BYTE_MODE                    BOOLEAN                 IN/OUT

 ABSOLUTE_OFFSET                BINARY_INTEGER          IN     DEFAULT

 RELATIVE_OFFSET                BINARY_INTEGER          IN     DEFAULT

PROCEDURE GET_LINE

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         VARCHAR2                OUT

 LEN                            BINARY_INTEGER          IN     DEFAULT

PROCEDURE GET_LINE_NCHAR

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         NVARCHAR2               OUT

 LEN                            BINARY_INTEGER          IN     DEFAULT

PROCEDURE GET_RAW

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         RAW                     OUT

 LEN                            BINARY_INTEGER          IN     DEFAULT

FUNCTION IS_OPEN RETURNS BOOLEAN

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

PROCEDURE NEW_LINE

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 LINES                          BINARY_INTEGER          IN     DEFAULT

PROCEDURE PUT

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         VARCHAR2                IN

PROCEDURE PUTF

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 FORMAT                         VARCHAR2                IN

 ARG1                           VARCHAR2                IN     DEFAULT

 ARG2                           VARCHAR2                IN     DEFAULT

 ARG3                           VARCHAR2                IN     DEFAULT

 ARG4                           VARCHAR2                IN     DEFAULT

 ARG5                           VARCHAR2                IN     DEFAULT

PROCEDURE PUTF_NCHAR

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 FORMAT                         NVARCHAR2               IN

 ARG1                           NVARCHAR2               IN     DEFAULT

 ARG2                           NVARCHAR2               IN     DEFAULT

 ARG3                           NVARCHAR2               IN     DEFAULT

 ARG4                           NVARCHAR2               IN     DEFAULT

 ARG5                           NVARCHAR2               IN     DEFAULT

PROCEDURE PUT_LINE

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         VARCHAR2                IN

 AUTOFLUSH                      BOOLEAN                 IN     DEFAULT

PROCEDURE PUT_LINE_NCHAR

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         NVARCHAR2               IN

PROCEDURE PUT_NCHAR

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         NVARCHAR2               IN

PROCEDURE PUT_RAW

 Argument Name                  Type                    In/Out Default?

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

 FILE                           RECORD                  IN

   ID                           BINARY_INTEGER          IN

   DATATYPE                     BINARY_INTEGER          IN

   BYTE_MODE                    BOOLEAN                 IN

 BUFFER                         RAW                     IN

 AUTOFLUSH                      BOOLEAN                 IN     DEFAULT


SYS> CREATE OR REPLACE PROCEDURE create_user (

  2    p_user_name VARCHAR2, p_

  3  BEGIN

  4  END;

  5  /


Warning: Procedure created with compilation errors.


SYS> ED

Wrote file afiedt.buf


  1  CREATE OR REPLACE PROCEDURE create_user (

  2    p_user_name VARCHAR2) IS

  3  BEGIN

  4    execute immediate 'CREATE USER ' || p_user_name || ' IDENTIFIED BY ' || p_user_name);

  5* END;

SYS> /       


Warning: Procedure created with compilation errors.


SYS> show error

Errors for PROCEDURE CREATE_USER:


LINE/COL ERROR

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

4/86     PLS-00103: Encountered the symbol ")" when expecting one of the

         following:

         . ( * @ % & = - + ; < / > at in is mod remainder not rem

         return returning <an exponent (**)> <> or != or ~= >= <= <>

         and or like like2 like4 likec between into using || bulk

         member submultiset

         The symbol "(" was substituted for ")" to continue.


SYS> ed

Wrote file afiedt.buf


  1  CREATE OR REPLACE PROCEDURE create_user (

  2    p_user_name VARCHAR2) IS

  3  BEGIN

  4    execute immediate 'CREATE USER ' || p_user_name || ' IDENTIFIED BY ' || p_user_name;

  5* END;

SYS> /


Procedure created.


SYS> exec create_user

BEGIN create_user; END;


      *

ERROR at line 1:

ORA-06550: line 1, column 7:

PLS-00306: wrong number or types of arguments in call to 'CREATE_USER'

ORA-06550: line 1, column 7:

PL/SQL: Statement ignored



SYS> exec create_user('hjs');


PL/SQL procedure successfully completed.


SYS> desc dba_users;

 Name                                                              Null?    Type

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

 USERNAME                                                          NOT NULL VARCHAR2(30)

 USER_ID                                                           NOT NULL NUMBER

 PASSWORD                                                                   VARCHAR2(30)

 ACCOUNT_STATUS                                                    NOT NULL VARCHAR2(32)

 LOCK_DATE                                                                  DATE

 EXPIRY_DATE                                                                DATE

 DEFAULT_TABLESPACE                                                NOT NULL VARCHAR2(30)

 TEMPORARY_TABLESPACE                                              NOT NULL VARCHAR2(30)

 CREATED                                                           NOT NULL DATE

 PROFILE                                                           NOT NULL VARCHAR2(30)

 INITIAL_RSRC_CONSUMER_GROUP                                                VARCHAR2(30)

 EXTERNAL_NAME                                                              VARCHAR2(4000)

 PASSWORD_VERSIONS                                                          VARCHAR2(8)

 EDITIONS_ENABLED                                                           VARCHAR2(1)

 AUTHENTICATION_TYPE                                                        VARCHAR2(8)


SYS> select username from dba_users;


USERNAME

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

MGMT_VIEW

SYS

SYSTEM

DBSNMP

SYSMAN

JSHONG

HR

U2

HJS

U1

OUTLN


USERNAME

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

WMSYS

APPQOSSYS

DIP

ORACLE_OCM


15 rows selected.


SYS> set timing on

SYS> alter system set cursor_sharing = EXACT;


System altered.


Elapsed: 00:00:00.04

SYS> create tablespace query_data

  2  datafile '/u01/app/oracle/oradata/orcl/query_data01.dbf' size 100m

  3  autoextend on next 10m maxsize 500m;

  

Tablespace created.


Elapsed: 00:00:03.68

SYS> connect hr/hr

Connected.

HR> create table big_table (c1 number, c2 varchar2(200)) tablespace query_data;


Table created.


Elapsed: 00:00:00.06

HR> declare 

  2  i number;

  3  str varchar2(200);

  4  begin

  5    for i in 1..100000 loop

  6      str := 'insert into big_table values ('||i||', RPAD('||i||', 100, ''*''))';

  7      execute immediate str;

  8    end loop;

  9  end;

 10  /


PL/SQL procedure successfully completed.


Elapsed: 00:00:28.39

HR> truncate table big_table;


Table truncated.


Elapsed: 00:00:00.46

HR> declare 

  2  i number;

  3  str varchar2(200);

  4  begin

  5    str:= 'insert into big_table values (:x1, :x2)';

  6    for i in 1..100000 loop

  7      execute immediate str using i, RPAD(i, 100, '*');

  8    end loop;

  9  end;

 10  /


PL/SQL procedure successfully completed.


Elapsed: 00:00:03.43

HR> set timing off

HR> 



'스마트웹&콘텐츠 개발자 과정 > PL SQL' 카테고리의 다른 글

PL/SQL 1일차  (0) 2018.07.23

Pseudo Column (의사 결정 컬럼)

    • ROWNUM : Top-N 분석 시 사용
               1부터 시작
    • ROWID : 물리적 Row 주소값


* Top-N 분석 예제 :
employees 테이블에서 최상위 소득자 3명의 이름과 급여를 표시하시오.
HR> select ROWNUM as RANK, last_name, salary
  2  from (select last_name, salary from employees order by salary DESC)
  3  where ROWNUM <= 3;

      RANK LAST_NAME                     SALARY
---------- ------------------------- ----------
         1 Whalen                         25000
         2 King                           24000
         3 Kochhar                        17000


HR> select ROWNUM as RANK, last_name, hire_date
  2  from (select last_name, hire_date from employees order by hire_date DESC)
  3  where ROWNUM <= 5;

      RANK LAST_NAME                 HIRE_DATE
---------- ------------------------- ---------
         1 Zlotkey                   29-JAN-00
         2 Mourgos                   16-NOV-99
         3 Grant                     24-MAY-99
         4 Lorentz                   07-FEB-99
         5 Vargas                    09-JUL-98


* ROWID 예시 :


ROWID              EMPLOYEE_ID LAST_NAME

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

AAAETOAAEAAAAELAAL         149 Zlotkey

AAAETOAAEAAAAELAAM         174 Abel

AAAETOAAEAAAAELAAN         176 Taylor

AAAETOAAEAAAAELAAO         178 Grant

AAAETOAAEAAAAELAAP         200 Whalen

AAAETOAAEAAAAELAAQ         201 Hartstein

AAAETOAAEAAAAELAAR         202 Fay

AAAETOAAEAAAAELAAS         205 Higgins

AAAETOAAEAAAAELAAT         206 Gietz



※ 6 3 6 3으로 끊으면 된다.

AAAEY/   AAE   AAAAFb   AAT

  6       3       6      3

Object# Field# Block#  Row#



select min(rowid), employee_id, last_name

from t1

group by employee_id, last_name

order by 2;

※ group by절에는 group function을 제외한 나머지 컬럼이 반드시 들어가야 한다.




* 중복을 제거!


방법 1 :


delete from t1

where rowid not in (select(min(rowid) from t1

                    group by employee_id);



방법 2 : 별칭을 주어 rowid 최소값보다 큰 것들을 제거


delete from t1 a

where rowid > (select min(rowid) from t1 b

               where a.employee_id = b.employee_id);




* mission! 급여 상위 6 ~ 10위를 추출하라.



'스마트웹&콘텐츠 개발자 과정 > Oracle' 카테고리의 다른 글

Workshop II 남은 부분 수업  (0) 2018.07.24
admin 수업 마지막  (0) 2018.07.03
admin 수업  (0) 2018.06.22
Admin 수업 - 백업 실습  (0) 2018.06.21
admin  (0) 2018.06.20

SYS> conn hr/hr

Connected.

HR> create table emp as select * from employees;


Table created.


HR> create index emp_id_no on emp(employee_id);


Index created.


HR> insert into emp select * from emp;


20 rows created.


HR> /


40 rows created.


HR> /


80 rows created.


HR> /


160 rows created.


HR> /


320 rows created.


HR> /


640 rows created.


HR> /


1280 rows created.


HR> /


2560 rows created.


HR> /


5120 rows created.


HR> /


10240 rows created.


HR> /


20480 rows created.


HR> /


40960 rows created.


HR> commit;


Commit complete.


HR> select sum(blocks) from user_segments where segment_name = 'EMP';


SUM(BLOCKS)

-----------

        896


HR> delete from emp;


81920 rows deleted.


HR> insert into emp select * from employees;


20 rows created.


HR> commit;


Commit complete.


HR> alter table emp shrink space check;

alter table emp shrink space check

*

ERROR at line 1:

ORA-10636: ROW MOVEMENT is not enabled



HR> select table_name, row_movement from user_tables where table_name = 'EMP';


TABLE_NAME                     ROW_MOVE

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

EMP                            DISABLED


HR> alter table emp enable row movement;


Table altered.


HR> select table_name, row_movement from user_tables where table_name = 'EMP';


TABLE_NAME                     ROW_MOVE

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

EMP                            ENABLED


HR> alter table emp shrink space check;

alter table emp shrink space check

*

ERROR at line 1:

ORA-10655: Segment can be shrunk



HR> alter table emp shrink space compact;


Table altered.


HR> alter table emp shrink space;


Table altered.


HR> select sum(blocks) from user_segments where segment_name = 'EMP';


SUM(BLOCKS)

-----------

          8


HR> create table rp_emp

  2  partition by range(department_id) (

  3  partition p_10 values less than (30) tablespace new_users,

  4  partition p_30 values less than (60) tablespace users,

  5  partition p_50 values less than (90) tablespace new_users,

  6  partition p_70 values less than (maxvalue) tablespace users)

  7  as        

  8  select * from employees;


Table created.


HR> insert into rp_emp   

  2  select * from rp_emp;


20 rows created.


HR> /


40 rows created.


HR> /


80 rows created.


HR> /


160 rows created.


HR> commit;


Commit complete.


HR> create table hp_emp

  2  partition by hash(employee_id) partitions 4

  3  store in (users, new_users)

  4  as select * from employees;


Table created.


HR> insert into hp_emp

  2  select * from hp_emp;


20 rows created.


HR> /


40 rows created.


HR> /


80 rows created.


HR> /


160 rows created.


HR> /


320 rows created.


HR> commit;


Commit complete.


HR> select table_name, partition_name from user_tab_partitions;


TABLE_NAME                     PARTITION_NAME

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

RP_EMP                         P_70

RP_EMP                         P_50

RP_EMP                         P_30

RP_EMP                         P_10

HP_EMP                         SYS_P23

HP_EMP                         SYS_P24

HP_EMP                         SYS_P22

HP_EMP                         SYS_P21


8 rows selected.


HR> select count(*) from rp_emp partition (p_10);


  COUNT(*)

----------

        48


HR> select count(*) from rp_emp partition (p_30);


  COUNT(*)

----------

        80


HR> select count(*) from rp_emp partition (p_50);


  COUNT(*)

----------

        96


HR> select count(*) from rp_emp partition (p_70);


  COUNT(*)

----------

        96


HR> select count(*) from rp_emp partition (sys_p21);

select count(*) from rp_emp partition (sys_p21)

                                       *

ERROR at line 1:

ORA-02149: Specified partition does not exist



HR> select count(*) from hp_emp partition (sys_p21);


  COUNT(*)

----------

        96


HR> select count(*) from hp_emp partition (sys_p22);


  COUNT(*)

----------

       128


HR> select count(*) from hp_emp partition (sys_p23);


  COUNT(*)

----------

       256


HR> select count(*) from hp_emp partition (sys_p24);


  COUNT(*)

----------

       160


HR> conn / as sysdba 

Connected.

SYS> select tp.endian_format

  2  from v$transportable_platform tp, v$database d

  3  where tp.platform_name = d.platform_name;


ENDIAN_FORMAT

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

Little






Cluster Table 실습



HR> conn hr/hr

Connected.

HR> create cluster emp_dept_clu(department_id number(4))

  2  tablespace users;


Cluster created.


HR> create index emp_dept_clu_ind

  2  on cluster emp_dept_clu

  3  tablespace users;


Index created.


HR> create table dept_clu cluster emp_dept_clu(department_id)

  2  as select * from departments;


Table created.


HR> create table emp_clu cluster emp_dept_clu(department_id)    

  2  as select * from departments;


Table created.


HR> drop table emp_clu;


Table dropped.


HR> create table emp_clu cluster emp_dept_clu(department_id)

  2  as select * from employees;


Table created.


HR> select rowid, department_id from dept_clu

  2  where department_id = 50;


ROWID              DEPARTMENT_ID

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

AAAETCAAEAAAADPAAA            50


HR> select rowid, employee_id, department_id from emp_clu

  2  where department_id = 50;


ROWID              EMPLOYEE_ID DEPARTMENT_ID

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

AAAETCAAEAAAADPAAA         124            50

AAAETCAAEAAAADPAAB         141            50

AAAETCAAEAAAADPAAC         142            50

AAAETCAAEAAAADPAAD         143            50

AAAETCAAEAAAADPAAE         144            50

 



'스마트웹&콘텐츠 개발자 과정 > Oracle' 카테고리의 다른 글

ROWID를 이용한 중복 제거  (0) 2018.07.26
admin 수업 마지막  (0) 2018.07.03
admin 수업  (0) 2018.06.22
Admin 수업 - 백업 실습  (0) 2018.06.21
admin  (0) 2018.06.20

> sqlplus / as sysdba > startup > conn hr/hr


HR> select first_name from employees where employee_id=100;


FIRST_NAME

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

Steven


HR> DECLARE

  2  v_fname VARCHAR2(20);

  3  BEGIN

  4  SELECT first_name INTO v_fname FROM employees

  5  WHERE employee_id=100;

  6  END;

  7  /


PL/SQL procedure successfully completed.


HR> ed

Wrote file afiedt.buf


  1  DECLARE

  2  v_fname VARCHAR2(20);

  3  BEGIN

  4  SELECT first_name INTO v_fname FROM employees

  5  WHERE employee_id=100;

  6* END;

HR> show serveroutput

serveroutput OFF

HR> set serveroutput on

HR> ed      

Wrote file afiedt.buf


  1  DECLARE

  2  v_fname VARCHAR2(20);

  3  BEGIN

  4  SELECT first_name INTO v_fname FROM employees

  5  WHERE employee_id=100;

  6  DBMS_OUTPUT.PUT_LINE(' The First Name of the Employee is ' || v_fname);

  7* END;

HR> /

The First Name of the Employee is Steven


PL/SQL procedure successfully completed.


HR> BEGIN


HR> DBMS_OUTPUT.PUT_LINE('Hello World');

SP2-0734: unknown command beginning "DBMS_OUTPU..." - rest of line ignored.

HR> begin

  2  dbms_output.put_line('Hello World');

  3  end;

  4  /

Hello World


PL/SQL procedure successfully completed.


HR> save lab_01_02

Created file lab_01_02.sql




* 변수에 & 해서 old, new값 안 볼 때 : set verify off

* procedure successfully ~ 보기 싫을 때 : set feedback off



declare

  v_maxdid departments.department_id%type;

  v_rows varchar2(100);

begin

  select max(department_id)

  into v_maxdid

  from departments;

  dbms_output.put_line('Maximum department id is '||v_maxdid);


  insert into departments

  values (v_maxdid+10, '&b_dname', null, null);

  v_rows := sql%rowcount || ' row inserted';

  dbms_output.put_line(v_rows);

end;

/




'스마트웹&콘텐츠 개발자 과정 > PL SQL' 카테고리의 다른 글

마지막 수업  (0) 2018.07.30

자바 수업 6일차 (마지막)



☞ 스윙 이어서...


* 자바에서는 클래스 내부에 새로운 클래스를 포함하여 사용하는 것을 허용한다.

  - 이러한 클래스를 내부inner 클래스라 한다.

  - 내부 클래스는 다른 용도로도 사용할 수 있지만, 이벤트를 처리할 때 유용하다.


1
2
3
4
5
6
7
class OutClass {
    ......
    class InnerClass {  // 내부 클래스 선언.
        ......          // 외부 클래스의 모든 요소 사용 가능.
    }
    ......
}
cs


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
 
class Event2 extends JFrame {
    JLabel jl;  // 버튼과 라벨을 클래스의 속성으로 지정.
    JButton jb1, jb2;
    
    public Event2() {
        Container ct = getContentPane();
        ct.setLayout(new FlowLayout());
        
        jb1 = new JButton("사랑합니다.");
        jb2 = new JButton("행복합니다.");
        jl = new JLabel("버튼을 누르세요.");
        jb1.addActionListener(new EventProcess());  // 두 개의 버튼에 리스너를 등록.
        jb2.addActionListener(new EventProcess());  // 처리 객체로 내부 클래스 지정.
        ct.add(jb1);
        ct.add(jb2);
        ct.add(jl);
        
        setTitle("Event Test2");
        setSize(250150);
        setVisible(true);
    }
    private class EventProcess implements ActionListener {
    // 내부 클래스로 인터페이스를 포함하는 클래스 작성.
        public void actionPerformed(ActionEvent e) {  // 이벤트 처리 루틴 작성.
            jl.setText(e.getActionCommand());  // 외부 클래스의 속성인 라벨을 직접 사용.
                                               // ActionEvent 객체를 이용하여
                                               // 버튼의 라벨값을 추출.
        }
    }
}
public class EventTest2 {
    public static void main(String[] args) {
        new Event2();
    }
}
cs



* 이벤트 처리를 위한 클래스를 별도로 작성하여 이벤트를 처리하는 방법


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
 
class EventClass implements ActionListener {  // 별도의 이벤트 처리 클래스 생성.
    JLabel jl;
    public EventClass(JLabel jl) {
        this.jl = jl;
    }
    public void actionPerformed(ActionEvent e) {
        jl.setText(e.getActionCommand());
    }
}
class Event3 extends JFrame {
    JLabel jl;
    JButton jb1, jb2;
    public Event3() {
        Container ct = getContentPane();
        ct.setLayout(new FlowLayout());
        
        jb1 = new JButton("사랑합니다.");
        jb2 = new JButton("행복합니다.");
        jl = new JLabel("버튼을 누르세요.");
        jb1.addActionListener(new EventClass(jl));  // 리스너를 등록.
        jb2.addActionListener(new EventClass(jl));  // 처리 객체를 지정할 때 JLabel 객체 전달.
        ct.add(jb1);
        ct.add(jb2);
        ct.add(jl);
        
        setTitle("Event Test3");
        setSize(250150);
        setVisible(true);
    }
}
public class EventTest3 {
    public static void main(String[] args) {
        new Event3();
    }
}
cs



* ImageIcon 클래스

  - 이미지를 아이콘화하여 제공하는 클래스이다.

  - [형식]

ImageIcon(String filename)

ImageIcon(URL url)

※ filename : 이미지 파일을 지정하여 아이콘을 생성.

   url : 웹 주소를 지정하여 아이콘을 생성.


* JLabel 클래스

  - 라벨을 만드는 클래스이다.

  - [형식]

JLabel(ImageIcon i)

JLabel(String s)

JLabel(String s, ImageIcon i, int align)

※ i : ImageIcon 객체로 라벨 생성.

   s : 문자열을 사용하여 라벨 생성.

   align : 아이콘과 문자열의 위치를 의미.

           SwingConstants 인터페이스의 상수를 사용.

           (SwingConstants.LEFT, SwingConstants.RIGHT, SwingConstants.CENTER, SwingConstants.LEADING, SwingConstants.TRAILING)


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
 
class JLabel1 extends JFrame implements ActionListener {
    private JLabel result = new JLabel();  // 이벤트 처리를 위해 속성으로 선언.
    public ImageIcon i1, i2;
    
    public JLabel1() {
        i1 = new ImageIcon("image/apple.jpg");  // 이미지 아이콘 객체 생성.
        i2 = new ImageIcon("image/pear.jpg");
        
        JButton apple = new JButton("사과");
        JButton pear = new JButton("배");
        
        Container ct = getContentPane();
        
        ct.setLayout(new FlowLayout());
        ct.add(apple);
        ct.add(pear);
        ct.add(result);
        
        apple.addActionListener(this);  // 버튼 객체에 리스너 등록.
        pear.addActionListener(this);
        
        setTitle("JLabel Test1");
        setSize(300250);
        setVisible(true);
    }
    public void actionPerformed(ActionEvent ae) {
        if(ae.getActionCommand() == "사과") {  // 버튼에 따라 결과를 출력.
            result.setText("맛있는 사과입니다.");
            result.setIcon(i1);  // 라벨의 아이콘을 설정.
        } else {
            result.setText("맛있는 배입니다.");
            result.setIcon(i2);
        }
    }
}
public class JLabelTest1 {
    public static void main(String[] args) {
        new JLabel1();
    }
}
cs



* 텍스트 클래스

  - 한 줄 : JTextField

  - 여러 줄 : JTextArea

  - [형식]

JTextField()

JTextField(int cols)

JTextField(String str, int cols)

JTextField(String str)

JTextArea()

JTextArea(String str)

JTextArea(int rows, int cols)

JTextArea(String str, int rows, int cols)

※ str : 생성될 때 나타낼 문자열.

   cols, rows : 텍스트 필드 또는 텍스트 에리어의 화면에서의 크기.

                입력되는 문자의 수와는 상관 없음.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
 
class JTFJTA1 extends JFrame implements ActionListener {
    JTextField jtf;  // 텍스트 객체 선언.
    JTextArea  jta;
    JLabel jl = new JLabel("입력하세요.");  // 라벨 객체 생성.
    public JTFJTA1() {
        jtf = new JTextField(20);
        jta = new JTextArea(1020);
        jta.setEditable(false);  // 텍스트 에리어 수정 불가 설정.
        
        Container ct = getContentPane();
        ct.setLayout(new FlowLayout());
        
        JPanel jp = new JPanel();  // 패널 객체 생성.
        jp.add(jtf);  // 패널에 추가.
        jp.add(jta);
        
        ct.add(jp);  // 컨테이너에 패널 추가.
        ct.add(jl);
        
        jtf.addActionListener(this);
        
        setTitle("JTextField, JTextArea Test1");
        setSize(500300);
        setVisible(true);
    }
    public void actionPerformed(ActionEvent ae) {
        if(jta.getLineCount() <= jta.getRows()) {
        // 텍스트의 크기(줄)보다 작을 때만 추가.
            jta.append(ae.getActionCommand()+"\n");
            jtf.setText("");  // 새로운 입력을 받기 위해, 기존의 내용을 비움.
        } else {
            jl.setText("입력이 종료되었습니다.");  // 크기를 넘어서면 라벨을 출력하고,
            jtf.setEditable(false);              // 텍스트 필드 수정 불가 설정.
        }
    }
}
public class JTFJTATest1 {
    public static void main(String[] args) {
        new JTFJTA1();
    }
}
cs




* JList 클래스

  - [형식]

JList()

JList(Object[] items)

※ items : 리스트로 생성할 배열.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import javax.swing.*;
import java.awt.*;
import javax.swing.event.*;  // 스윙 이벤트 패키지 포함.
 
class JList1 extends JFrame implements ListSelectionListener {
    private String[] fruitlist = {"persimmon""banana""apple""grape""cherry""pear"};  // 과일 이름 배열 생성.
    private JList jlst = new JList(fruitlist);  // 이름 배열로 리스트 객체 생성.
    private ImageIcon[] fruiticons = {  // 아이콘 객체 배열 생성.
            new ImageIcon("image/persimmon.jpg"),
            new ImageIcon("image/banana.jpg"),
            new ImageIcon("image/apple.jpg"),
            new ImageIcon("image/grape.jpg"),
            new ImageIcon("image/cherry.jpg"),
            new ImageIcon("image/pear.jpg")
    };
    private JLabel[] jlicon = new JLabel[6];  // 아이콘을 위한 라벨 객체 배열 생성.
    private JLabel jlname = new JLabel();  // 라벨을 저장할 객체 생성.
    
    public JList1() {
        Container ct = getContentPane();
        
        JPanel jp1 = new JPanel();
        jp1.setLayout(new GridLayout(3,2,5,5));  // 아이콘 패널 Grid 배치 관리자 설정.
        for (int i=0; i<6; i++) {
            jp1.add(jlicon[i] = new JLabel());
        }
        
        JPanel jp2 = new JPanel();
        jp2.add(jlname);
        ct.add(jlst, BorderLayout.WEST);  // Border 배치 관리자로 설정.
        ct.add(jp1, BorderLayout.CENTER);
        ct.add(jp2, BorderLayout.EAST);
        
        jlst.addListSelectionListener(this);  // 리스트에 리스너 등록.
        
        setTitle("JList Test1");
        setSize(700300);
        setVisible(true);
    }
    public void valueChanged(ListSelectionEvent lse) {
        for (int i=1; i<6; i++) {  // 아이콘을 모두 삭제.
            jlicon[i].setIcon(null);
        }
        int[] indices = jlst.getSelectedIndices();  // 선택된 항목을 배열로 추출.
        String s = "당신이 선택한 항목은 : ";
        for (int j=0; j<indices.length; j++) {  // 선택된 아이콘을 표시.
            jlicon[j].setIcon(fruiticons[indices[j]]);
            s = s + fruitlist[indices[j]] + " ";  // 선택된 아이콘의 문자열을 생성.
        }
        jlname.setText(s);  // 선택한 아이콘의 문자열 표시.
    }
}
public class JListTest1 {
    public static void main(String[] args) {
        new JList1();
    }
}
cs




수고하셨습니다.



+ Recent posts