56 Commits

Author SHA1 Message Date
c94cde0682 Add a popupmenu to queryhelpers which contains 2 items with shortcuts:
+ Delete [Del] (Deletes a snippetfile)
  + Help [F1] (Calls SQL help for selected keyword or function)
2007-07-27 22:36:19 +00:00
2866e00f59 Change defaults for HandleErrors and DisplayErrors to FALSE. The other way around causes way too many bugs. 2007-07-27 14:46:38 +00:00
f18cf13097 Bugfix: EnsureActiveDatabase() is a helper function, it shouldn't gobble up exceptions.
(There we go with that default "HandleErrors = true" thing again...)
2007-07-27 14:36:16 +00:00
17fc590309 Bugfix: If snippets list is active and a new snippet is saved, refresh the list. 2007-07-27 11:47:07 +00:00
5ae56fe00c Code cleanup; use hideExt instead of extra Copy(). 2007-07-27 11:23:24 +00:00
37a5951835 * Add version of GetFilesFromDir() that hides file extensions.
* Change SQL snippet menus and lists to hide the .sql extension.
2007-07-27 11:10:20 +00:00
7807465aa6 Bugfix: Problem in logical construct; tab was always switched when not in drag mode, which was obviously not the intention.
Bugfix: Hiding tabs causes the active tab to switch implicitly.  Move code that depends on the active tab to happen before tabs are hidden.
Change: Don't switch away from query tab when switching tables etc.
2007-07-27 10:51:54 +00:00
3174feaf64 Doh.. fix "Clear" item when Filter memo is active. 2007-07-26 07:05:38 +00:00
8d896f732d Followup to rev 756:
* Hide new menuitems when SynMemoFilter is focused.
* Call SynMemoQuery.OnChange in popupQuery.Popup to ensure various menuitems are dis-/enabled
* Disable "Clear" item when memo is empty
2007-07-26 06:45:45 +00:00
5cecd6a91e Minor: Change format of "123,456,789 Characters" above querymemo to a better readable "123,4 MB" 2007-07-26 06:07:01 +00:00
021d56e0bc Clean up and enhance popupQuery menu:
* Bring items in a better, usable order
* Nuke dependency of hardcoded itemcount in code for SQL functions: "popupQuery.Items[i+13].Add(mi);"
* Add useful actions:
  + Insert file at cursor
  + Save selection to file
  + Save as snippet
  + Save selection as snippet
* Assign procedures for menuLoad + menuSave at designtime, not at runtime (which made sense in a MDI mechanism)
* Minor optimization of detecting selected text in SynMemo
2007-07-25 21:18:20 +00:00
6d8f8e1299 Implement a dialog/mechanism to run a SQL file directly without loading it into the query editor (= memory):
1. When user opens a file which is bigger than LOAD_SIZE (currently 5M), ask what to do
2. User can normally open the file, cancel, or use the new mechanism:
3. Load a chunk of LOAD_SIZE of SQL into memory
4. Split chunk with parseSQL into single queries
5. Run queries and go on with 3.

parseSQL is the bottleneck here, very CPU consuming, as it has to take care of different comment-styles and delimiters. So, the above strategy effected a good compromise regarding overall performance on different tests with worst case SQL files:
- "Wide" table exports with many big sized fields => long lines
- "Narrow" table exports with only one mini-sized field, extended INSERTs => short lines
Especially in the latter case it avoids to cause a hellfire of parseSQL-calls

Still seems to have some memory leaks somewhere.
2007-07-23 20:25:29 +00:00
561b057d5c Bugfix: Fix a (silenced) double reset of running flag caused by redundant CheckConnection calls, which in turn caused reconnect logic to break wrt manually fired queries.
Bugfix: FetchActiveDb...() is a helper function, do not try to handle exceptions as it leads to AVs.
Bugfix: ShowTableProperties() is a helper function, do not try to handle exceptions as it leads to AVs.
Bugfix: AV in ShowProcessList when disconnected.
Bugfix: AV in ShowVariablesAndProcesses when disconnected.  (Something tells me it could be better to let the default for HandleErrors be 'false', a lot of these seems to pop up during testing...)
Bugfix: Connected time counter did not stop when connection got dropped.
Bugfix: Uptime counter did not stop when connection got dropped.
viewdata(): Use standard method of fetching data to get rid of redundant code.
...BeforeSendingSql(): Remove now redundant code.
2007-07-23 15:03:34 +00:00
8e10529741 New feature: Enable column renaming from within listColumns.
Side-effect: Needed to change some editor-related shortcuts so they don't trigger their corresponding menu-commands from popupTableGrid when the user presses them at the time the column name gets edited:
- Call field editor : Now "Alt+Enter", was "Enter"
- Drop field : Now "Ctrl+Del", was "Del"
2007-07-15 06:45:47 +00:00
457db77cc8 Simplify code: Use one try-except block instead of two for procedures which can throw exceptions. 2007-07-14 20:46:57 +00:00
c711a29254 Remove superflous code which has no longer any visible effect since revision 745. Selected table item keeps focus because ShowDBProperties is not called any longer. 2007-07-14 19:14:58 +00:00
8573b7401d Fix: Restore previously set mousecursor after using crHourGlass. Fixes staying crHourGlass after renaming a table. 2007-07-14 19:09:20 +00:00
2f3bcd9e38 Enhancement: Only refresh table cache after renaming, don't refresh the listview. In any error case don't rename the list-item. 2007-07-14 19:03:59 +00:00
490e192ca9 Call help window when pressing F1 in those query helpers tabs for which that makes sense. 2007-07-14 18:31:14 +00:00
d6da05aa13 Add a splitter between query memo and helpers which recalls its position set in the last session. 2007-07-14 18:21:00 +00:00
f49e9f9e41 New Feature. Add SQL snippets to query helpers in a new tab 2007-07-14 18:03:27 +00:00
f39222fea5 Refresh table cache when one or more tables got renamed, created, dropped. 2007-07-14 12:59:25 +00:00
8e391548d4 Fix restoring column names with spaces from ORDER clause in registry 2007-07-13 05:25:15 +00:00
064ed3b4da Decide to refresh data if the OK button in any of the two dialogs (column_selection, data_sorting) was pressed. Don't call viewdata in the dialogs, but in ChildWin itself. Saves some superflous procedures / code. 2007-07-12 22:44:05 +00:00
cc84963b25 Implement a dialog for easier accessing the options for ordered columns.
This has one positive side effect: ViewData no longer re-saves an ORDERCLAUSE to registry after it has been read. At the same time the ORDERCLAUSE is read everytime when grid is filled, not only the first time. Those changes were needed to be able to apply an ORDERCLAUSE which was generated and saved by the new dialog.

Left for later: Moving order-columns up and down. Tested that with a TUpDown which seems to ignore clicks sometimes and then doesn't fire OnClick.
2007-07-12 22:33:59 +00:00
4d12bd3e42 Send focus back to query editor after a column name has been double clicked into it. 2007-07-12 09:54:59 +00:00
2c0caa154d Bugfix: 'stop on errors when executing sql batch' got broken in revision 667. 2007-07-12 09:47:38 +00:00
37f0b45363 Display rowcount statistics in a wordwrapped TLabel. Makes room for coming buttons "ORDER" (and "GROUP"). 2007-07-08 19:10:21 +00:00
40eb52729a Remove a done TODO-note 2007-07-07 18:54:32 +00:00
6936031742 Replace a note on the loaddata-form about an unsupported feature by a simple version check routine which enables/disables the calling controls. 2007-07-07 18:51:02 +00:00
1e6b065015 Fix rowcount statistics for pre-4.0 servers.
See also: http://www.heidisql.com/forum/viewtopic.php?p=1046#1046
2007-07-07 11:16:47 +00:00
31c65c9e2f Display flash-icon in menuitems for functions. 2007-07-06 22:10:12 +00:00
86f01b4675 Attach server version to SQL functions and use that to hide unsupported functions in query helpers, popupQuery and SynCompletionProposal. 2007-07-06 22:07:05 +00:00
5207ec37a7 Move popupmenu main.SQLfunctions to childwin.popupQuery. So every new created MDI-child get its own instance of this popupmenu. 2007-07-06 19:10:04 +00:00
5d82d7661f Fix AV after unsuccessful table renaming. 2007-07-06 06:01:23 +00:00
feb47109f5 Code rearrangement. 2007-07-05 13:01:54 +00:00
69e1abbf43 Implement an up-to-date list of MySQL functions in mysql.pas. Used for
- popupmenu in query memo
- query helpers
- SynCompletionProposal
Drops function.txt and parser for that file.

Pros:
- No dependency on this file anymore
- Much easier and safer coding
- File-parsing no longer needed

Notes:

The old function.txt was meant to be editable and extensible for users but I never saw or heard anyone who does that, most likely because it wasn't documented. Another problem was that the file resided in the programs-directory, where only administrators have write-access, so in these cases it couldn't be edited anyway.

The PHP file in /extras can be used for creating an up-to-date list for mysql.pas .

As not all functions of the new list are available in all mysql-versions, it would be the best if we would fetch the list by the use of HELP commands. Contra: Would result in poor performancing popupmenu and many servers don't have the help-tables filled.
2007-07-04 22:31:56 +00:00
01c66955f6 Important followup to last commit: Makes EnsureActiveDatabase accessible in other units. 2007-07-04 20:19:36 +00:00
79c95bd9fd Move creation of SQLhelp from application startup to a place where it's done on demand.
Move public property keyword to the private context as it is no longer accessed from outside.
2007-07-03 20:22:49 +00:00
3e2517ee6f Move creation of tablecomment from application startup to a place where it's done on demand. 2007-07-03 19:17:54 +00:00
45d617c776 Move creation of tbl_properties_form from application startup to a place where it's done on demand.
Also removes a legacy procedure where that form was called, which is not linked to any control event.
2007-07-03 19:10:45 +00:00
7a80a82f11 Move creation of CreateTableForm from application startup to a place where it's done on demand. 2007-07-03 18:25:25 +00:00
ef08999839 OnlyDBs2 no longer needs to be public, since it's not accessed from selectsomedatabases-dialog. 2007-07-03 06:03:41 +00:00
ce0956bf8f Drop dialog for selecting databases to display. As discussed it has no performance problem any longer to handle more than 50 dbs. 2007-07-03 05:53:29 +00:00
003f0956aa Fix check for filled lboxQueryHelpers which prevented it from being updated with columns from new table. 2007-07-02 19:18:20 +00:00
4b168a9587 Remove superflous call to Items.Sorted. 2007-07-02 07:50:42 +00:00
22adaf2439 Remember last selected item in query helpers tabs. 2007-07-02 06:23:41 +00:00
7d8bd255ff We rely on OnDragOver checking for valid source controls. So, add a default insertion text for situations in which all typecastings fail. This text should never be visible. 2007-07-02 06:09:07 +00:00
5cbebfe42c Implement query helpers: Columns, SQL functions and SQL keywords, presented in a listbox where they can be doubleclicked or dragged to insert into query-memo.
As a benefit, function.txt is read into 3 stringlists at startup now: Names, Declarations and Descriptions. Used in SynCompletionProposal and to fill the above mentioned helpers-list.

Also fixes a minor issue in SynMemoQueryDragOver using an unset "Accept" var.
2007-07-01 23:29:42 +00:00
134f23e82c Sanitize component names located in main pagecontrol. 2007-07-01 19:33:31 +00:00