PostgreSql

General Help regarding HMG, Compilation, Linking, Samples

Moderator: Rathinagiri

Post Reply
User avatar
perenne
Posts: 3
Joined: Fri Aug 01, 2008 12:02 pm
Location: Brasil

PostgreSql

Post by perenne »

Good afternoon.

Need an example in accessing HMG postgresql.
User avatar
Rathinagiri
Posts: 5471
Joined: Tue Jul 29, 2008 6:30 pm
DBs Used: MariaDB, SQLite, SQLCipher and MySQL
Location: Sivakasi, India
Contact:

Re: PostgreSql

Post by Rathinagiri »

You can see the examples, if you download the harbour 1.0 source code under contrib directory.

Here is a sample from there, dbf2pg.prg

Code: Select all

/*
 *
 * $Id: dbf2pg.prg 8755 2008-06-19 16:33:10Z vszakats $
 *
 * Harbour Project source code:
 * dbf2pg.prg - converts a .dbf file into a Postgres table
 *
 * Copyright 2000 Maurilio Longo <maurilio.longo@libero.it>
 * www - http://www.harbour-project.org
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2, or (at your option)
 * any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this software; see the file COPYING.  If not, write to
 * the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
 * Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
 *
 * As a special exception, the Harbour Project gives permission for
 * additional uses of the text contained in its release of Harbour.
 *
 * The exception is that, if you link the Harbour libraries with other
 * files to produce an executable, this does not by itself cause the
 * resulting executable to be covered by the GNU General Public License.
 * Your use of that executable is in no way restricted on account of
 * linking the Harbour library code into it.
 *
 * This exception does not however invalidate any other reasons why
 * the executable file might be covered by the GNU General Public License.
 *
 * This exception applies only to the code released by the Harbour
 * Project under the name Harbour.  If you copy code from other
 * Harbour Project or Free Software Foundation releases into a copy of
 * Harbour, as the General Public License permits, the exception does
 * not apply to the code that you add in this way.  To avoid misleading
 * anyone as to the status of such modified files, you must delete
 * this exception notice from them.
 *
 * If you write modifications of your own for Harbour, it is your choice
 * whether to permit this exception to apply to your modifications.
 * If you do not wish that, delete this exception notice.
 *
 * The Original file was ported from Mysql and changed by Rodrigo Moreno rodrigo_moreno@yahoo.com
 *
 */

#include "inkey.ch"
#include "common.ch"

#define CRLF chr(13) + chr(10)

procedure main(c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11, c12, c13, c14, c15, c16, c17, c18, c19, c20)

   local cTok, nTok := 1
   local cHostName := "localhost"
   local cUser := "postgres"
   local cPassWord := ""
   local cDataBase, cTable, cFile
   local aDbfStruct, i
   local lCreateTable := .F.
   local oServer, oTable, oRecord
   Local cField
   Local sType
   Local dType
   Local cValue
   Local nCommit := 100
   Local nHandle
   Local nCount := 0
   Local nRecno := 0
   Local lTruncate := .F.
   Local lUseTrans := .F.
   Local cPath := 'public'

   SET CENTURY ON
   SET EPOCH TO 1960
   SET DELETE ON
   SET DATE FORMAT "dd/mm/yyyy"

   rddSetDefault( "DBFDBT" )

   if PCount() < 6
      help()
      quit
   endif

   i := 1
   // Scan parameters and setup workings
   while (i <= PCount())
      
      cTok := PValue(i++)

      do case
      case cTok == "-h"
         cHostName := PValue(i++)

      case cTok == "-d"
         cDataBase := PValue(i++)

      case cTok == "-t"
         cTable := PValue(i++)

      case cTok == "-f"
         cFile := PValue(i++)

      case cTok == "-u"
         cUser := PValue(i++)

      case cTok == "-p"
         cPassWord := PValue(i++)

      case cTok == "-c"
         lCreateTable := .T.

      case cTok == "-x"
         lTruncate := .T.

      case cTok == "-s"
         lUseTrans := .T.
         
      case cTok == "-m"
         nCommit := val(PValue(i++))

      case cTok == "-r"
         nRecno := val(PValue(i++))

      case cTok == "-e"
         cPath := PValue(i++)

      otherwise
         help()
         quit
      endcase
   enddo

   // create log file
   if (nHandle := FCreate(Trim(cTable) + '.log')) == -1
        ? 'Cannot create log file'
        quit
   endif        

   USE (cFile) SHARED
   aDbfStruct := DBStruct()

   oServer := TPQServer():New(cHostName, cDatabase, cUser, cPassWord, nil, cPath)
   if oServer:NetErr()
      ? oServer:Error()
      quit
   endif
   
   oServer:lallCols := .F.

   if lCreateTable
      if oServer:TableExists(cTable)
         oServer:DeleteTable(cTable)
         if oServer:NetErr()
            ? oServer:Error()
            FWrite( nHandle, "Error: " + oServer:Error() + CRLF )
            FClose( nHandle )
            quit
         endif
      endif
      oServer:CreateTable(cTable, aDbfStruct)

      if oServer:NetErr()
         ? oServer:Error()
         FWrite( nHandle, "Error: " + oServer:Error() + CRLF )
         FClose( nHandle )
         quit
      endif
   endif
   
   if lTruncate
        oServer:Execute('truncate table ' + cTable)        
        if oServer:NetErr()
            ? oServer:Error()
            FWrite( nHandle, "Error: " + oServer:Error() + CRLF )
            FClose( nHandle )
            quit
        endif        
   endif

   oTable := oServer:Query("SELECT * FROM " + cTable + " LIMIT 1")
   if oTable:NetErr()
      Alert(oTable:Error())
      FWrite( nHandle, "Error: " + oTable:Error() + CRLF )
      FClose( nHandle )
      quit
   endif

   if lUseTrans
      oServer:StartTransaction()
   endif      
   
   FWrite( nHandle, "Start: " + time() + CRLF )

   ? "Start: ", time()
   ? 
   
   if ! Empty(nRecno)
      dbgoto(nRecno)
   endif      

   while ! eof() .and. Inkey() != K_ESC .and. (empty(nRecno) .or. nRecno == recno())
      oRecord := oTable:GetBlankRow()
      
      for i := 1 to oTable:FCount()
         cField := lower(oTable:FieldName(i))
         sType := fieldtype(fieldpos(cField))
         dType := oRecord:Fieldtype(i)
         cValue := fieldget(fieldpos(cField))
         
         if ! ISNIL(cValue)
            if dType != sType           
               if dType == 'C' .and. sType == 'N'
                 cValue := Str(cValue)
                 
               elseif dType == 'C' .and. sType == 'D'
                 cValue := DtoC(cValue)
            
               elseif dType == 'C' .and. sType == 'L'
                 cValue := IIF( cValue, "S", "N" )
                 
               elseif dType == 'N' .and. sType == 'C'
                 cValue := val(cValue)
                 
               elseif dType == 'N' .and. sType == 'D'
                 cValue := Val(DtoS(cValue))
            
               elseif dType == 'N' .and. sType == 'L'
                 cValue := IIF( cValue, 1, 0 )
                 
               elseif dType == 'D' .and. sType == 'C'
                 cValue := CtoD(cValue)
                 
               elseif dType == 'D' .and. sType == 'N'
                 cValue := StoD(Str(cValue))
                 
               elseif dType == 'L' .and. sType == 'N'
                 cValue := ! Empty(cValue)

               elseif dType == 'L' .and. sType == 'C'
                 cValue := IIF( alltrim(cValue) $ "YySs1", .T., .F. )                                                  
            
               end
            end            
            
            if ! ISNIL(cValue)
                if oRecord:Fieldtype(i) == 'C' .or. oRecord:Fieldtype(i) == 'M'                    
                    oRecord:FieldPut(i, hb_oemtoansi(cValue))
                else                    
                    oRecord:FieldPut(i, cValue)
                endif                                        
            endif
         endif
      next

      oTable:Append(oRecord)
      
      if oTable:NetErr()
         ?
         ? "Error Record: ", recno(), left(oTable:Error(),70)
         ? 
         FWrite( nHandle, "Error at record: " + Str(recno()) + " Description: " + oTable:Error() + CRLF )         
      else
         nCount++         
      endif

      dbSkip()

      if (nCount % nCommit) == 0
         DevPos(Row(), 1)
         DevOut("imported recs: " + Str(nCount))         
         
         if lUseTrans
            oServer:commit()
            oServer:StartTransaction()
         endif            
      endif
   enddo
   
   if (nCount % nCommit) != 0
        if lUseTrans
            oServer:commit()
        endif            
   endif        

   FWrite( nHandle, "End: " +  time() + ", records in dbf: " + ltrim(str(recno())) + ", imported recs: " + ltrim(str(nCount)) + CRLF )

   ? "End: ", time()
   ? 

   FClose( nHandle )

   close all
   oTable:Destroy()
   oServer:Destroy()
return


procedure Help()

   ? "dbf2pg - dbf file to PostgreSQL table conversion utility"
   ? "-h hostname (default: localhost)"
   ? "-u user (default: root)"
   ? "-p password (default no password)"
   ? "-d name of database to use"
   ? "-t name of table to add records to"
   ? "-c delete existing table and create a new one"
   ? "-f name of .dbf file to import"
   ? "-x truncate table before append records"
   ? "-s use transaction"
   ? "-m commit interval"
   ? "-r insert only record number"
   ? "-e search path"
   
   ? ""

return
East or West HMG is the Best.
South or North HMG is worth.
...the possibilities are endless.
mgreavu
Posts: 3
Joined: Fri Nov 07, 2008 11:56 am

Re: PostgreSql

Post by mgreavu »

I get this errors :

undefined reference to PQfreemem

and many others....


Mihai Greavu
User avatar
raumi75
Posts: 135
Joined: Wed Dec 17, 2008 2:31 am
Location: Lünen, Germany
Contact:

Re: PostgreSql

Post by raumi75 »

I get the same errors. IMHO the package is simply not included in the standard hmg-distribution.

Has anybody managed to compile the contrib package with mingw? It would be awesome if we could get it to work under windows with mingw.

Right now, I am using odbc to connect to our postgresql-server. But hbpgsql seems to be a lot more convenient and sophisticated.

Jan
User avatar
raumi75
Posts: 135
Joined: Wed Dec 17, 2008 2:31 am
Location: Lünen, Germany
Contact:

Re: PostgreSql

Post by raumi75 »

Hello everybody,

it works with HMG 3.00! Hurray! Thank you Meister Lopez!

Thanks to the samples, I am starting to understand how it works.
Maybe all I needed was the information, that dlls from the PostgreSQL-website were required.

Is anybody else using this library?

Jan
User avatar
Roberto Lopez
HMG Founder
Posts: 4004
Joined: Wed Jul 30, 2008 6:43 pm

Re: PostgreSql

Post by Roberto Lopez »

raumi75 wrote:Hello everybody,

it works with HMG 3.00! Hurray! Thank you Meister Lopez!

Thanks to the samples, I am starting to understand how it works.
Maybe all I needed was the information, that dlls from the PostgreSQL-website were required.

Is anybody else using this library?

Jan
Thanks. I was going to point that. It is working in 3.0 and samples are included.
Regards/Saludos,

Roberto


(Veritas Filia Temporis)
User avatar
Rathinagiri
Posts: 5471
Joined: Tue Jul 29, 2008 6:30 pm
DBs Used: MariaDB, SQLite, SQLCipher and MySQL
Location: Sivakasi, India
Contact:

Re: PostgreSql

Post by Rathinagiri »

Thanks Jan for the info. I would also try.
East or West HMG is the Best.
South or North HMG is worth.
...the possibilities are endless.
User avatar
sudip
Posts: 1454
Joined: Sat Mar 07, 2009 11:52 am
Location: Kolkata, WB, India

Re: PostgreSql

Post by sudip »

Hello Friends,

This was my humble try with PGSql viewtopic.php?f=5&t=875&start=14

With best regards.

Sudip
With best regards,
Sudip
User avatar
raumi75
Posts: 135
Joined: Wed Dec 17, 2008 2:31 am
Location: Lünen, Germany
Contact:

Re: PostgreSql

Post by raumi75 »

Hello,

I really like that the .exe-files run on any windows client without having to run an installer first.

Now, I have to make sure, that the dll-files are installed on every computer that runs my program.

But maybe you can help me. :-) is it possible to link the required libraries (libpq, etc.) into the exe, so that installation of the dll-files is not needed.

Raumi
mgreavu
Posts: 3
Joined: Fri Nov 07, 2008 11:56 am

Re: PostgreSql

Post by mgreavu »

Many thanks from Romania,for this version 3.00 with postgresql direct support, senor Roberto !

Mihai Greavu
Post Reply