view m-toolbox/classes/@repogui2/buildquery.m @ 39:11e3ed9d2115
database-connection-manager
Implement databases listing in database connection dialog
author |
Daniele Nicolodi <nicolodi@science.unitn.it> |
date |
Mon, 05 Dec 2011 16:20:06 +0100 (2011-12-05) |
parents |
f0afece42f48 |
children |
|
line source
% BUILDQUERY build a query from the settings on the query panel
%
% M Hewitson
%
% $Id: buildquery.m,v 1.2 2011/04/08 08:56:37 hewitson Exp $
%
function buildquery(varargin)
mainfig = varargin{end};
% Get number of conditions
Nc = mainfig.Nconditions;
% Select fields
fieldList = findobj(mainfig.handle, 'Tag', 'fieldsList');
fieldsStr = get(fieldList, 'String');
vals = get(fieldList, 'Value');
fields = fieldsStr(vals);
% Get table
tableSel = findobj(mainfig.handle, 'Tag', 'tableSelect');
tbls = get(tableSel, 'String');
tbl = tbls{get(tableSel, 'Value')};
% Start the query
q = 'SELECT ';
for j=1:length(fields)
q = [q fields{j} ','];
end
q = [q(1:end-1) ' FROM ' tbl];
for k=1:Nc
if k==1
q = [q ' WHERE '];
end
% get field
h = findobj(mainfig.handle, 'Tag', sprintf('c%02dField', k));
fields = get(h, 'String');
field = fields{get(h, 'Value')};
q = [q field];
% get condition
h = findobj(mainfig.handle, 'Tag', sprintf('c%02dCondition', k));
conds = get(h, 'String');
cond = conds{get(h, 'Value')};
q = [q ' ' cond ' '];
% get value
h = findobj(mainfig.handle, 'Tag', sprintf('c%02dValue', k));
val = get(h, 'String');
q = [q '"' val '"'];
% Get compound
if k<Nc
h = findobj(mainfig.handle, 'Tag', sprintf('c%02dCompound', k));
comps = get(h, 'String');
comp = comps{get(h, 'Value')};
q = [q ' ' comp ' '];
end
end
% Order by
h = findobj(mainfig.handle, 'Tag', 'fieldOrderBy');
fields = get(h, 'String');
field = fields{get(h, 'Value')};
q = [q ' ORDER BY ' field];
h = findobj(mainfig.handle, 'Tag', 'sortDir');
dirs = get(h, 'String');
dir = dirs{get(h, 'Value')};
q = [q ' ' dir ';'];
% Set query string on GUI
h = findobj(mainfig.handle, 'Tag', 'queryDisplayTxt');
set(h, 'String', q);
drawnow
end