mol wrote:
Where to find info about RDDI - how to create database?
You may find info at hmg300\SAMPLES\RDD.SQL\Readme.txt (I installed HMG3.0.0 test in a separate folder).
There is also a more detailed sample, I recently discovered from Minigui Ext at \MiniGUI\SAMPLES\Advanced\MYSQLDD.
I can't resist myself to put the sample here for my friends who didn't install Minigui Ext. Please note that I want to learn only. And thanks a lot for the sample to Grigory Filatov 
 
Code: Select all
/*
 * MINIGUI - Harbour Win32 GUI library Demo
 *
 * Copyright 2002-2008 Roberto Lopez <harbourminigui@gmail.com>
 * http://harbourminigui.googlepages.com/
 *
 * Copyright 2008 Grigory Filatov <gfilatov@freemail.ru>
 *
 * Based on RDDSQL sample included in Harbour distribution
*/
#include "minigui.ch"
#include "dbinfo.ch"
#include "error.ch"
#define DBI_QUERY             1001
#define RDDI_CONNECT          1001
#define RDDI_DISCONNECT       1002
#define RDDI_EXECUTE          1003
#define RDDI_ERROR            1004
#define RDDI_ERRORNO          1005
#define RDDI_NEWID            1006
#define RDDI_AFFECTEDROWS     1007
#define RDDI_QUERY            1008
ANNOUNCE RDDSYS
REQUEST SDDMY, SQLMIX
MEMVAR memvarcountryname
MEMVAR memvarcountryresidents
*--------------------------------------------------------*
Function Main()
*--------------------------------------------------------*
	RDDSETDEFAULT( "SQLMIX" )
	IF RDDINFO( RDDI_CONNECT, {"MYSQL", "localhost", "root",, "test"} ) == 0
		MsgStop("Unable connect to the server!", "Error")
		Return nil
	ENDIF
	DEFINE WINDOW Form_1 ;
		AT 0,0 ;
		WIDTH 640 HEIGHT 480 ;
		TITLE 'MiniGUI SQL Database Driver Demo' ;
		MAIN NOMAXIMIZE ;
		ON INIT OpenTable() ;
		ON RELEASE CloseTable()
		DEFINE MAIN MENU
			DEFINE POPUP 'Test'
				MENUITEM 'Add record'	ACTION AddRecord('ARG', 'Argentina', 38740000)
				SEPARATOR	                                       			                                    
				ITEM "Exit"		ACTION ThisWindow.Release()
			END POPUP
		END MENU
		@ 10,10 BROWSE Browse_1	;
			WIDTH 610	;
			HEIGHT 390	;	
			HEADERS { 'Code' , 'Name' , 'Residents' } ;
			WIDTHS { 50 , 160 , 100 } ;
			WORKAREA country ;
			FIELDS { 'country->Code' , 'country->Name' , 'country->Residents' } ;
			JUSTIFY { BROWSE_JTFY_LEFT, BROWSE_JTFY_LEFT, BROWSE_JTFY_RIGHT } ;
			EDIT ;
			VALID { , { || sqlupdate(2) } , { || sqlupdate(3) } } ;
			READONLY { .T. , .F. , .F. }
	END WINDOW
	CENTER WINDOW Form_1
	ACTIVATE WINDOW Form_1
Return nil
*--------------------------------------------------------*
Procedure OpenTable
*--------------------------------------------------------*
   If CreateTable()
	DBUSEAREA( .T.,, "SELECT * FROM country", "country" )
	INDEX ON FIELD->RESIDENTS TAG residents TO country
	GO TOP
   Else
	Form_1.Release()
   EndIf
Return
*--------------------------------------------------------*
Procedure CloseTable
*--------------------------------------------------------*
   DBCLOSEALL()
Return
*--------------------------------------------------------*
Procedure AddRecord(cCode, cName, nResidents)
*--------------------------------------------------------*
   If RDDINFO(RDDI_EXECUTE, "INSERT INTO country values ('" + cCode + "', '" + cName + "', " + ltrim(str(nResidents)) + ")")
      // MsgInfo( RDDINFO(RDDI_AFFECTEDROWS), "Count of Affected Rows" )
      APPEND BLANK
      REPLACE CODE WITH cCode, ;
              NAME WITH cName, ;
              RESIDENTS WITH nResidents
      Form_1.Browse_1.Value := country->(RecNo())
      Form_1.Browse_1.Refresh
   Else
	MsgStop("Can't append record to table Country!", "Error")
   EndIf
Return
*--------------------------------------------------------*
Function sqlupdate(nColumn)
*--------------------------------------------------------*
Local nValue := Form_1.Browse_1.Value
Local cCode, cField, cNewValue
   If nColumn == 2
	cField := "Name"
	cNewValue := "'" + Memvar.Country.Name + "'"
   ElseIf nColumn == 3
	cField := "Residents"
	cNewValue := ltrim(str(Memvar.Country.Residents))
   EndIf
   GO nValue
   cCode := "'" + country->CODE + "'"
   If ! RDDINFO(RDDI_EXECUTE, "UPDATE country SET " + cField + " = " + cNewValue + " WHERE CODE = " + cCode)
	MsgStop("Can't update record in table Country!", "Error")
	Return .F.
   EndIf
Return .T.
*--------------------------------------------------------*
Function CreateTable
*--------------------------------------------------------*
Local ret := .T.
   RDDINFO(RDDI_EXECUTE, "DROP TABLE country")
   If RDDINFO(RDDI_EXECUTE, "CREATE TABLE country (CODE char(3), NAME char(50), RESIDENTS int(11))")
      If ! RDDINFO(RDDI_EXECUTE, "INSERT INTO country values ('LTU', 'Lithuania', 3369600), ('USA', 'United States of America', 305397000), ('POR', 'Portugal', 10617600), ('POL', 'Poland', 38115967), ('AUS', 'Australia', 21446187), ('FRA', 'France', 64473140), ('RUS', 'Russia', 141900000)")
	MsgStop("Can't fill table Country!", "Error")
	ret := .F.
      EndIf
   Else
	MsgStop("Can't create table Country!", "Error")
	ret := .F.
   EndIf
Return ret
With best regards.
Sudip