Ola!
put. que par... vai gostar de DBF assim lá longe... porque ficar diferente de tudo que é linguagem de programação?
Quem disse que é da forma que vc está pensando e escrevendo erradamente ?
Vc não sabe. Eu usei e uso ADO e SQLMIX.
Todos vão precisar converter o "RESULTADO" a sentença SQL, para a linguagem em questão.
Vai ver como o PHP abre um SGBD em SQL e manipula o ARRAY. Cada linguagem tem sua forma de MANIPULAR os DADOS.
SQL é UNIVERSAL, mas a forma como cada linguagem trata o RETORNO(RESULT), é que faz a diferença.
Nós programadores xBASE estamos acostumados usar SKIP, GOTO... Como vc faz para ir para o topo de uma array usando PHP por exemplo ?
Vc está condicionado ao ADO, precisa se descondicionar. Qual é o mais fácil RS:MOVE_ETC... ou DBGOTOP() ?
ADO é para quem está APENAS no WINDOWS.
SQLMIX não salvamos nem alteramos NADA, usam SQL para isso. MANIPULAMOS o resultado usando SINTAXE DBF(xBase), nos movemos nele pq é DBF_ARRAY.
Não é um arquivo físico. E funciona em LINUX e WINDOWS é parte integrante de Harbour.
A mesma coisa é a classe do Rodrigo Moreno para Postgree não tem nada de ADO, nem de SQLMIX.
Código: Selecionar todos
#require "hbpgsql"
PROCEDURE Main( cHost, cDatabase, cUser, cPass )
LOCAL cQuery, oQuery, oRow, i, x
LOCAL oServer := TPQServer():New( cHost, hb_defaultValue( cDatabase, "postgres" ), cUser, cPass )
IF oServer:NetErr()
? oServer:ErrorMsg()
RETURN
ENDIF
oServer:SetVerbosity( 2 )
oServer:traceon( "simple.log" )
? "Tables..."
FOR EACH i IN oServer:ListTables()
? i
NEXT
IF oServer:TableExists( "test" )
? oQuery := oServer:Execute( "DROP TABLE test" )
oQuery:Destroy()
ENDIF
? "Creating test table..."
cQuery := ;
"CREATE TABLE test(" + ;
" Code integer not null primary key," + ;
" dept Integer," + ;
" Name Varchar(40)," + ;
" Sales boolean," + ;
" Tax Float4," + ;
" Salary Double Precision," + ;
" Budget Numeric(12,2)," + ;
" Discount Numeric(5,2)," + ;
" Creation Date," + ;
" Description text )"
oQuery := oServer:Query( cQuery )
IF oQuery:NetErr()
? oQuery:ErrorMsg()
ENDIF
oQuery:Destroy()
? "Structure of test table"
FOR EACH i IN oServer:TableStruct( "test" )
?
FOR EACH x IN i
?? x, ""
NEXT
NEXT
? "Inserting, declared transaction control"
oServer:StartTransaction()
FOR i := 1 TO 10
cQuery := "INSERT INTO test(code, dept, name, sales, tax, salary, budget, Discount, Creation, Description) " + ;
"VALUES( " + hb_ntos( i ) + ", 2, 'TEST', 'y', 5, 3000, 1500.2, 7.5, '2003-12-17', 'Short Description about what ?')"
oQuery := oServer:Query( cQuery )
IF oQuery:NetErr()
? oQuery:errorMsg()
ENDIF
oQuery:destroy()
NEXT
oServer:Commit()
oQuery := oServer:Query( "SELECT code, name, description, sales FROM test" )
FOR EACH i IN oQuery:Struct()
? i[ 1 ], i[ 2 ], i[ 3 ], i[ 4 ]
NEXT
? "Fields:", oQuery:FCount()
oRow := oQuery:Blank()
? ;
oRow:FCount(), ;
oRow:FieldPos( "sales" ), ;
oRow:FieldGet( 1 ), ;
oRow:FieldName( 2 ), ;
oRow:FieldType( 1 ), ;
oRow:FieldDec( 1 ), ;
oRow:FieldLen( 1 )
oRow:FieldPut( 1, 150 )
oRow:FieldPut( 2, "MY TEST" )
? oRow:FieldGet( 1 ), oRow:FieldGet( 2 )
? oRow:aRow[ 1 ], oRow:aRow[ 2 ], oRow:aOld[ 1 ], oRow:aOld[ 2 ]
? oQuery:Append( oRow )
? oQuery:ErrorMsg()
DO WHILE ! oQuery:Eof()
? ;
oQuery:RecNo(), ;
oQuery:FieldPos( "code" ), ;
oQuery:FieldGet( oQuery:FieldPos( "code" ) ), ;
oQuery:FieldGet( 4 ), ;
oQuery:FieldGet( 2 ), ;
oQuery:FieldName( 1 ), ;
oQuery:FieldType( 1 ), ;
oQuery:FieldDec( 1 ), ;
oQuery:FieldLen( 1 ), ;
oQuery:FieldGet( 3 )
IF oQuery:RecNo() == 50
oRow := oQuery:getrow()
oRow:FieldPut( 2, "My Second test" )
? "Update:", oQuery:Update( oRow )
ENDIF
IF oQuery:RecNo() == 60
oRow := oQuery:getrow()
? "Delete:", oQuery:Delete( oRow )
ENDIF
oQuery:Skip()
ENDDO
oQuery:Refresh()
FOR i := 1 TO oQuery:LastRec()
oRow := oQuery:getrow( i )
? i, ;
oRow:FieldGet( oRow:FieldPos( "code" ) ), ;
oRow:FieldGet( 4 ), ;
oRow:FieldGet( 2 ), ;
oRow:FieldName( 1 ), ;
oRow:FieldType( 1 ), ;
oRow:FieldDec( 1 ), ;
oRow:FieldLen( 1 ), ;
oRow:FieldGet( i, 3 )
NEXT
oQuery:Destroy()
oServer:Destroy()
? "Closing..."
RETURN
Olha ai uma outra forma que ele criou, para trabalhar com o resultado do ARRAY quem vem.
Veja que ele usa a mesma técnica. Ora parece ADO, ora ele usa LASTREC()...
Não é questão de PIOR nem MELHOR, DBSKIP, não é melhor nem PIOR que RS:MOVELAST, e vice versa.
Saudações,
Itamar M. Lins Jr.