Mercurial > hg > ltpda
view m-toolbox/classes/@repogui/cb_executeQuery.m @ 38:3aef676a1b20 database-connection-manager
Keep backtrace on error
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% Execute the query built on the query panel % % M Hewitson % % $Id: cb_executeQuery.m,v 1.7 2011/04/08 08:56:26 hewitson Exp $ % function cb_executeQuery(varargin) % Get connection mainfig = varargin{end}; conn = mainfig.connection; if isempty(conn) error('### Please connect to a database first.'); end if ischar(varargin{end-1}) q = varargin{end-1}; fields = 'id'; else % Get Selected fields fieldList = findobj(mainfig.handle, 'Tag', 'fieldsList'); fieldsStr = get(fieldList, 'String'); vals = get(fieldList, 'Value'); fields = fieldsStr(vals)'; % Get query h = findobj(mainfig.handle, 'Tag', 'queryDisplayTxt'); q = get(h, 'String'); end try curs = exec(conn, q); curs = fetch(curs); results = curs.Data; close(curs) catch warning('!!! Unable to execute query %s', q) % warning('!!! Server returned: %s', curs.Message); results = {}; close(conn); conn = []; disp('* disconnected.'); mainfig.connection = conn; mainfig.username = ''; set(findobj('Tag', 'ConnectButton'), 'String', 'connect'); set(findobj(mainfig.handle, 'Tag', 'RepoguiStatusTxt'), 'String', 'not connected'); mainfig.dbuser = ''; mainfig.dbpass = ''; popup2change = [findobj(mainfig.handle, 'Tag', 'tableSelect'), findobj(mainfig.handle, 'Tag', 'fieldsList'), findobj(mainfig.handle,'-regexp','Tag','.*Field$')]; set(popup2change,'Value',1,'String',{'-'}) set(findobj(mainfig.handle, 'Tag', 'tableSelect'),'Value', 1) assignin('base','prova',mainfig) error('### Unable to execute query'); end status = findobj(mainfig.handle, 'Tag', 'RepoguiStatusTxt'); if ~isempty(results) if strcmp(results{1}, 'No Data') utils.helper.errorDlg('Query returned no results.', 'Query Empty'); set(status, 'String', ['*** No results to query: ' q], 'ForeGroundcolor','r'); return else set(status, 'String', sprintf('*** Query returned %d results', numel(results)), 'ForeGroundcolor','b'); repogui.sqlResultsGUI(results, fields, q); end end end