File px_heap_scan_join_info.cpp¶
File List > cubrid > src > query > parallel > px_heap_scan > px_heap_scan_join_info.cpp
Go to the documentation of this file
/*
*
* Copyright 2016 CUBRID Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
/*
* px_heap_scan_join_info.cpp
*/
#include "px_heap_scan_join_info.hpp"
#include "xasl.h"
// XXX: SHOULD BE THE LAST INCLUDE HEADER
#include "memory_wrapper.hpp"
namespace parallel_heap_scan
{
join_info::join_info()
: m_scan_infos ()
{
}
void join_info::capture_join_info (xasl_node *head)
{
xasl_node *xptr = head;
ACCESS_SPEC_TYPE *specp;
scan_info scan_info;
int n_scan_ptrs;
for (n_scan_ptrs = 0; xptr; xptr = xptr->scan_ptr, n_scan_ptrs++)
{
specp = xptr->curr_spec? xptr->curr_spec : xptr->spec_list;
if (specp->curent != NULL)
{
COPY_OID (&scan_info.oid, &specp->curent->oid);
HFID_COPY (&scan_info.hfid, &specp->curent->hfid);
if (specp->access == ACCESS_METHOD_INDEX)
{
BTID_COPY (&scan_info.btid, &specp->curent->btid);
}
}
else
{
COPY_OID (&scan_info.oid, &ACCESS_SPEC_CLS_OID (specp));
HFID_COPY (&scan_info.hfid, &ACCESS_SPEC_HFID (specp));
if (specp->access == ACCESS_METHOD_INDEX)
{
BTID_COPY (&scan_info.btid, &specp->btid);
}
}
scan_info.target_type = specp->type;
scan_info.access_method = specp->access;
if (specp->type == TARGET_LIST)
{
scan_info.list_id = ACCESS_SPEC_LIST_ID (specp);
}
else
{
scan_info.list_id = NULL;
}
scan_info.status = specp->s_id.status;
scan_info.qualified_block = specp->s_id.qualified_block;
m_scan_infos[xptr->header.id] = scan_info;
}
}
void join_info::record_join_info (XASL_ID xasl_id, xasl_node *xptr)
{
std::lock_guard<std::mutex> lock (m_mutex);
scan_info &scan_info = m_scan_infos[xasl_id];
scan_info.status = xptr->curr_spec->s_id.status;
scan_info.qualified_block = xptr->curr_spec->s_id.qualified_block;
}
void join_info::apply_join_info (xasl_node *xasl)
{
xasl_node *xptr;
ACCESS_SPEC_TYPE *specp;
std::lock_guard<std::mutex> lock (m_mutex);
for (xptr = xasl; xptr != NULL; xptr = xptr->scan_ptr)
{
scan_info &scan_info = m_scan_infos[xptr->header.id];
specp = xptr->curr_spec? xptr->curr_spec : xptr->spec_list;
specp->s_id.qualified_block = scan_info.qualified_block;
specp->s_id.status = S_ENDED;
specp->s_id.position = S_AFTER;
}
}
}