Storage¶
https://docs.oracle.com/cloud/latest/db112/CNCPT/logical.htm#CNCPT3000
A tablespace
is a logical storage container for segments. Segments are database objects, such as tables and indexes, that consume storage space.
A segment
is a set of extents allocated for a specific database object, such as a table. Each segment belongs to one and only one tablespace.
An extent
is a set of logically contiguous data blocks allocated for storing a specific type of information.
One logical data block
corresponds to a specific number of bytes of physical disk space, for example, 2 KB.
Tools¶
http://www.oracle.com/technetwork/developer-tools/index.html
User¶
ALTER USER hr ACCOUNT UNLOCK;
ALTER USER hr IDENTIFIED BY hr_password;
Create Table¶
https://docs.oracle.com/cd/B28359_01/server.111/b28310/tables003.htm#ADMIN11004
CREATE TABLE "HR"."COUNTRIES"
(
"COUNTRY_ID" CHAR(2 BYTE)
CONSTRAINT "COUNTRY_ID_NN" NOT NULL ENABLE,
https://docs.oracle.com/cd/B19306_01/server.102/b14200/clauses002.htm
"COUNTRY_NAME" VARCHAR2(40 BYTE),
"REGION_ID" NUMBER,
CONSTRAINT "COUNTRY_C_ID_PK" PRIMARY KEY ("COUNTRY_ID") ENABLE,
CONSTRAINT "COUNTR_REG_FK" FOREIGN KEY ("REGION_ID")
REFERENCES "HR"."REGIONS" ("REGION_ID") ENABLE
)
ORGANIZATION INDEX -- index-organized table.
ORGANIZATION: the order in which the data rows of the table are stored. - HEAP: the data rows of table are stored in no particular order. This is the default. - INDEX: table is created as an index-organized table. In an index-organized table, the data rows are held in an index defined on the primary key for the table. - EXTERNAL: table is a read-only table located outside the database.
NOCOMPRESS -- whether to compress data segments to reduce disk use
PCTFREE 10 -- NOCOMPRESS use the PCTFREE default value of 10, to maximize compress while still allowing for some future DML changes to the data
INITRANS 2 -- Specify the initial number of concurrent transaction entries allocated within each data block allocated to the database object.
MAXTRANS 255 -- deprecated.
LOGGING -- a database object will be logged in the redo log file
https://docs.oracle.com/cd/B28359_01/server.111/b28286/clauses.htm#SQLRF021
STORAGE(
INITIAL 65536 -- the size of the first extent of the object. allocates space when you create the schema object.
NEXT 1048576 -- in bytes the size of the next extent to be allocated to the object.
MINEXTENTS 1 -- In locally managed tablespaces, determine the initial segment size in conjunction with PCTINCREASE, INITIAL and NEXT
MAXEXTENTS 2147483645 -- valid only for objects in dictionary-managed tablespaces
PCTINCREASE 0 -- Oracle recommends a setting of 0 as a way to minimize fragmentation and avoid the possibility of very large temporary segments during processing.
FREELISTS 1 -- each free list group contains one free list
FREELIST GROUPS 1 -- In tablespaces with manual segment-space management, statically partition the segment free space in an Oracle Real Application Clusters environment.
BUFFER_POOL DEFAULT
FLASH_CACHE DEFAULT
CELL_FLASH_CACHE DEFAULT
)
https://docs.oracle.com/cd/B28359_01/server.111/b28286/clauses009.htm#SQLRF30013
TABLESPACE "USERS"
PCTTHRESHOLD 50; -- when an overflow segment is being used, defines the maximum size of the portion of the row that is stored in the index block, as a percentage of block size. 1–50. The default is 50.
Create Procedure¶
https://docs.oracle.com/cd/B19306_01/server.102/b14200/statements_6009.htm
CREATE PROCEDURE find_root
( x IN REAL )
IS LANGUAGE C
Use the call_spec to map a Java or C method name, parameter types, and return type to their SQL counterparts.
NAME c_find_root
LIBRARY c_utils
PARAMETERS ( x BY REFERENCE );
create or replace PROCEDURE add_job_history
( p_emp_id job_history.employee_id%type
, p_start_date job_history.start_date%type
, p_end_date job_history.end_date%type
, p_job_id job_history.job_id%type
, p_department_id job_history.department_id%type
)
IS
BEGIN
INSERT INTO job_history (employee_id, start_date, end_date, job_id, department_id)
VALUES(p_emp_id, p_start_date, p_end_date, p_job_id, p_department_id);
END add_job_history;