Commit 09965b80 authored by Boris Kocherov's avatar Boris Kocherov

use "All member" for cases if hierarchy for cubevalue does not have corresponding mamber

parent be315158
...@@ -52,7 +52,8 @@ ...@@ -52,7 +52,8 @@
cRef3D = AscCommonExcel.cRef3D, cRef3D = AscCommonExcel.cRef3D,
cEmpty = AscCommonExcel.cEmpty, cEmpty = AscCommonExcel.cEmpty,
cArray = AscCommonExcel.cArray, cArray = AscCommonExcel.cArray,
cubeScheme = {}; cubeScheme = {},
cubeExecutionScheme = {};
cFormulaFunctionGroup.Cube = cFormulaFunctionGroup.Cube || []; cFormulaFunctionGroup.Cube = cFormulaFunctionGroup.Cube || [];
cFormulaFunctionGroup.Cube.push(cCUBEKPIMEMBER, cCUBEMEMBER, cCUBEMEMBERPROPERTY, cCUBERANKEDMEMBER, cCUBESET, cFormulaFunctionGroup.Cube.push(cCUBEKPIMEMBER, cCUBEMEMBER, cCUBEMEMBERPROPERTY, cCUBERANKEDMEMBER, cCUBESET,
...@@ -106,6 +107,59 @@ ...@@ -106,6 +107,59 @@
}); });
} }
function discover_hierarchies(connection) {
var settings = getProperties(connection),
prop = settings.prop;
prop.restrictions = {
// 'CATALOG_NAME': 'FoodMart',
// 'HIERARCHY_NAME': hierarchy_name,
// 'HIERARCHY_UNIQUE_NAME': hierarchy_name,
'CUBE_NAME': settings.cube
};
return xmla_request_retry("discoverMDHierarchies", prop)
.push(function (response) {
var hierarchies = {},
hierarchy,
uname,
caption,
all_member,
dimension_uname,
dimension,
dimensions = {};
while (response.hasMoreRows()) {
uname = response.getHierarchyUniqueName();
caption = response.getHierarchyCaption();
all_member = response.getAllMember();
dimension_uname = response.getDimensionUniqueName();
dimension = dimensions[dimension_uname];
if (!dimension) {
dimension = {
uname: dimension_uname,
all_member: all_member
};
dimensions[dimension_uname] = dimension;
}
if (!dimension.all_member && all_member) {
dimension.all_member = all_member;
}
hierarchy = {
uname: uname,
caption: caption,
all_member: all_member,
dimension_uname: dimension_uname,
dimension: dimension
};
hierarchies[uname] = hierarchy;
hierarchies[caption] = hierarchy;
response.nextRow();
}
return {
hierarchies: hierarchies,
dimensions: dimensions
};
});
}
function getProperties(connection) { function getProperties(connection) {
var connections = { var connections = {
xmla: { xmla: {
...@@ -128,7 +182,32 @@ ...@@ -128,7 +182,32 @@
} }
function getScheme(connection) { function getScheme(connection) {
var scheme = cubeScheme[connection]; var scheme = cubeScheme[connection],
queue = new RSVP.Queue();
if (scheme) {
queue.push(function () {
return scheme;
});
} else {
queue
.push(function () {
return discover_hierarchies(connection);
})
.push(function (arg) {
scheme = {
members: {},
hierarchies: arg.hierarchies,
dimensions: arg.dimensions
};
cubeScheme[connection] = scheme;
return scheme;
});
}
return queue;
}
function getExecutionScheme(connection) {
var scheme = cubeExecutionScheme[connection];
if (scheme) { if (scheme) {
return scheme; return scheme;
} else { } else {
...@@ -136,7 +215,7 @@ ...@@ -136,7 +215,7 @@
members: {}, members: {},
hierarchies: {} hierarchies: {}
}; };
cubeScheme[connection] = scheme; cubeExecutionScheme[connection] = scheme;
return scheme; return scheme;
} }
} }
...@@ -224,18 +303,27 @@ ...@@ -224,18 +303,27 @@
})(); })();
function execute(connection) { function execute(connection) {
var scheme = getScheme(connection); var execution_scheme = getExecutionScheme(connection),
if (!scheme.execute) { scheme;
scheme.execute = RSVP.defer(); if (!execution_scheme.execute) {
new RSVP.Queue() execution_scheme.execute = RSVP.defer();
.push(function () { getScheme(connection)
.push(function (s) {
var settings = getProperties(connection), var settings = getProperties(connection),
prop = settings.prop, prop = settings.prop,
hierarchies = scheme.hierarchies, hierarchies = execution_scheme.hierarchies,
hierarchy, hierarchy,
mdx = []; mdx = [],
tuple_str,
all_member;
scheme = s;
for (hierarchy in hierarchies) { for (hierarchy in hierarchies) {
mdx.push("{" + hierarchies[hierarchy].join(",") + "}"); tuple_str = hierarchies[hierarchy].join(",");
all_member = scheme.hierarchies[hierarchy].all_member;
if (all_member) {
tuple_str = tuple_str + ',' + all_member;
}
mdx.push("{" + tuple_str + "}");
} }
prop.statement = "SELECT " + mdx.join("*") + prop.statement = "SELECT " + mdx.join("*") +
" ON 0 FROM [" + settings.cube + "]"; " ON 0 FROM [" + settings.cube + "]";
...@@ -251,6 +339,7 @@ ...@@ -251,6 +339,7 @@
axes: {length: axis_count}, axes: {length: axis_count},
members: {}, members: {},
hierarchies: {length: 0}, hierarchies: {length: 0},
hierarchies_info: scheme.hierarchies,
cells: [] cells: []
}; };
...@@ -312,42 +401,63 @@ ...@@ -312,42 +401,63 @@
cube.cells[cellset.cellOrdinal()] = cellset.cellValue(); cube.cells[cellset.cellOrdinal()] = cellset.cellValue();
} while (cellset.nextCell() > 0); } while (cellset.nextCell() > 0);
collectAxes(); collectAxes();
scheme.cube = cube; execution_scheme.cube = cube;
scheme.execute.resolve(cube); execution_scheme.execute.resolve(cube);
scheme.execute = null; execution_scheme.execute = null;
scheme.hierarchies = []; execution_scheme.hierarchies = [];
}) })
.push(undefined, function (error) { .push(undefined, function (error) {
console.error(error); console.error(error);
scheme.execute = null; execution_scheme.execute = null;
scheme.hierarchies = []; execution_scheme.hierarchies = [];
}); });
} }
return scheme.execute.promise; return execution_scheme.execute.promise;
} }
function discover_members(connection, members) { function discover_member(connection, member_name) {
var promises = [], var settings = getProperties(connection),
hierarchies = {}, prop = settings.prop,
scheme = getScheme(connection); cached_member,
scheme = getExecutionScheme(connection);
function discoverMember(connection, member_name) { prop.restrictions = {
var settings = getProperties(connection),
prop = settings.prop;
prop.restrictions = {
// 'CATALOG_NAME': 'FoodMart', // 'CATALOG_NAME': 'FoodMart',
'MEMBER_UNIQUE_NAME': member_name, 'MEMBER_UNIQUE_NAME': member_name,
'CUBE_NAME': settings.cube 'CUBE_NAME': settings.cube
}; };
cached_member = scheme.members[member_name];
if (cached_member) {
return new RSVP.Queue()
.push(function () {
return cached_member;
});
} else {
return xmla_request_retry("discoverMDMembers", prop) return xmla_request_retry("discoverMDMembers", prop)
.push(function (response) { .push(function (r) {
if (response.numRows > 0) { if (r.numRows > 0) {
return response; var uname = r.getMemberUniqueName(),
hierarchy = r.getHierarchyUniqueName(),
cached_member;
cached_member = {
uname: uname,
h: hierarchy,
caption: r.getMemberCaption(),
type: r.getMemberType()
};
if (!scheme.members.hasOwnProperty(uname)) {
scheme.members[uname] = cached_member;
}
return cached_member;
} else { } else {
throw "member not found"; throw "member not found";
} }
}); });
} }
}
function discover_members(connection, members) {
var promises = [],
hierarchies = {};
function check_interseption(hierarchy) { function check_interseption(hierarchy) {
if (hierarchies.hasOwnProperty(hierarchy)) { if (hierarchies.hasOwnProperty(hierarchy)) {
...@@ -358,31 +468,15 @@ ...@@ -358,31 +468,15 @@
} }
members.forEach(function (member) { members.forEach(function (member) {
var cached_member;
if (member) { if (member) {
cached_member = scheme.members[member]; promises
if (cached_member) { .push(
check_interseption(cached_member.h); discover_member(connection, member)
promises.push(cached_member); .push(function (member) {
} else { check_interseption(member.h);
promises return member;
.push(discoverMember(connection, member) })
.push(function (r) { );
var uname = r.getMemberUniqueName(),
hierarchy = r.getHierarchyUniqueName(),
cached_member;
check_interseption(hierarchy);
cached_member = {
uname: uname,
h: hierarchy,
caption: r.getMemberCaption()
};
if (!scheme.members.hasOwnProperty(uname)) {
scheme.members[uname] = cached_member;
}
return cached_member;
}));
}
} }
}); });
return RSVP.all(promises); return RSVP.all(promises);
...@@ -546,7 +640,7 @@ ...@@ -546,7 +640,7 @@
return queue return queue
.push(function (arg) { .push(function (arg) {
connection = getCell(arg[0]); connection = getCell(arg[0]);
scheme = getScheme(connection); scheme = getExecutionScheme(connection);
return parseArgs(arg.slice(1))(); return parseArgs(arg.slice(1))();
}) })
.push(function (members) { .push(function (members) {
...@@ -585,13 +679,9 @@ ...@@ -585,13 +679,9 @@
coordinate = [], coordinate = [],
i, i,
ret; ret;
for (i = 0; i < cube.hierarchies.length; i++) {
h = cube.hierarchies[i]; function getHierarchyByMember(member_path) {
coordinate[h.axis_id] = []; var h;
coordinate[h.axis_id][h.tuple_id] = null;
}
for (i = 0; i < members.length; i++) {
member_path = members[i];
h = cube.members[member_path]; h = cube.members[member_path];
if (h === undefined) { if (h === undefined) {
throw "query result not contain data for member:" + throw "query result not contain data for member:" +
...@@ -599,17 +689,40 @@ ...@@ -599,17 +689,40 @@
} }
h = h.hierarchy; h = h.hierarchy;
h = cube.hierarchies[h]; h = cube.hierarchies[h];
return h;
}
for (i = 0; i < cube.hierarchies.length; i++) {
h = cube.hierarchies[i];
if (!coordinate[h.axis_id]) {
coordinate[h.axis_id] = [];
}
coordinate[h.axis_id][h.tuple_id] = null;
}
for (i = 0; i < members.length; i++) {
member_path = members[i];
h = getHierarchyByMember(members[i]);
coordinate[h.axis_id][h.tuple_id] = member_path; coordinate[h.axis_id][h.tuple_id] = member_path;
} }
coordinate = coordinate.map(function (axis, axis_id) { coordinate = coordinate.map(function (axis, axis_id) {
axis.forEach(function (h, h_id) { return axis.map(function (h, h_id) {
if (h === null) { var hierarchy_name,
all_member;
if (!h) {
hierarchy_name = cube.hierarchies[axis_id + ',' + h_id].name;
all_member = cube.hierarchies_info[hierarchy_name].all_member;
if (all_member) {
h = getHierarchyByMember(all_member);
if (h) {
return all_member;
}
}
throw "Axis:" + axis_id + " hierarchy:" + throw "Axis:" + axis_id + " hierarchy:" +
cube.hierarchies[axis_id + ',' + h_id].name + cube.hierarchies[axis_id + ',' + h_id].name +
" not determinated"; " not determinated";
} }
}); return h;
return axis.join(','); }).join(',');
}); });
coordinate.forEach(function (tuple, axis_id) { coordinate.forEach(function (tuple, axis_id) {
var axis = cube.axes[axis_id]; var axis = cube.axes[axis_id];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment