Firstly we need to enable ORDS.
data:image/s3,"s3://crabby-images/4a5f1/4a5f1b15c0ec31114cf20c629f880e1efe94c063" alt=""
Base url : <SERVER_URL>:<SERVER_PORT>/ords/
To hide the schema name from the API endpoint we put any alias in the url mapping pattern.
BEGIN
ORDS.enable_schema(
p_enabled => TRUE,
p_schema => '<SCHEMA_NAME>',
p_url_mapping_type => 'BASE_PATH',
p_url_mapping_pattern => '<ANY_ALIAS_INPLACE_OF_SCHEMA_NAME>',
p_auto_rest_auth => FALSE
);
COMMIT;
END;
/
Till now our end is up to the below URL, and we can start building APIs.
<SERVER_URL>:SERVER_PORT>/ords/<ANY_ALIAS_INPLACE_OF_SCHEMA_NAME>
There are two ways to build the APIs
Quick Build
Manual Build
1. Quick Build
BEGIN
ORDS.define_service(
p_module_name => 'Quick_API_MODULE',
p_base_path => 'v1/',
p_pattern => 'employees/',
p_method => 'GET',
p_source_type => ORDS.source_type_collection_feed,
p_source => 'SELECT * FROM emp',
p_items_per_page => 0);
COMMIT;
END;
/
Check in DB and Restful APIs.
data:image/s3,"s3://crabby-images/ef442/ef442592adff5e5b6a0102f72ef4b78ad2dfce32" alt=""
Modules
SELECT id, name, uri_prefix
FROM user_ords_modules
where name = 'Quick_API_MODULE';
data:image/s3,"s3://crabby-images/292a9/292a9149486432b9ba34fbc3993d987f78f2b057" alt=""
Templates
SELECT id, module_id, uri_template
FROM user_ords_templates
where module_id= 822768;
data:image/s3,"s3://crabby-images/cb6e2/cb6e2fc578edd406c16055fb62fb16624fe9796a" alt=""
Handlers
SELECT id, template_id, source_type, method, source
FROM user_ords_handlers where
template_id= 822769;
data:image/s3,"s3://crabby-images/263c2/263c22207a3ea0df5e4bf6cc1c48a588a50cc5b1" alt=""
How url works
Base ORDS URL : <SERVER_URL>:SERVER_PORT>/ords/
Schema (alias): <SERVER_URL>:SERVER_PORT>/ords/<ANY_ALIAS_INPLACE_OF_SCHEMA_NAME>
Module : <SERVER_URL>:SERVER_PORT>/ords/<ANY_ALIAS_INPLACE_OF_SCHEMA_NAME>/Quick_API_MODULE
Template : <SERVER_URL>:SERVER_PORT>/ords/<ANY_ALIAS_INPLACE_OF_SCHEMA_NAME>/Quick_API_MODUL/employees/
2. Manual Build
-- Create module
ORDS.define_module(
p_module_name => 'TEST',
p_base_path => 'TEST',
p_items_per_page => 0);
-- Create tamplate
ORDS.define_template(
p_module_name => 'TEST',
p_pattern => 'employees/');
-- Create handler
ORDS.define_handler(
p_module_name => 'TEST',
p_pattern => 'employees/',
p_method => 'GET',
p_source_type => ORDS.source_type_collection_feed,
p_source => 'SELECT * FROM emp',
p_items_per_page => 0);
COMMIT;
END;
/