Re: Extremely Low performance with ODBC

Поиск
Список
Период
Сортировка
От Craig Ringer
Тема Re: Extremely Low performance with ODBC
Дата
Msg-id 483685EC.9040704@postnewspapers.com.au
обсуждение исходный текст
Ответ на Extremely Low performance with ODBC  ("Sebastian Rychter" <srychter@anvet.com.ar>)
Список pgsql-sql
Sebastian Rychter wrote:
> Hi, I'm executing a query through psql ODBC which is taking around 2 minutes
> to complete. When I run it from PgAdmin it takes less than 3 seconds.
> 
> The query itself has :
> 
> . 15 inner joins (from just around 10 different tables - the other inner
> joins are using different aliases for the same tables) 
> 
> . Select statement returns 1 field.
> 
> . the testing database is selecting only 1 record.
> 
>  
> 
> Taking a look at the explain analyze report, I see they are both quite the
> same and tested the ODBC driver through Visual Foxpro and Vb.NET as well,
> taking both around 2 minutes to finish.

Are you using prepared statements (or might the driver be doing so for 
you) ?

A common question here arises from the query planner making different 
decisions for a query based on whether or not it can see the values of 
query parameters. Consider:

SELECT something FROM tablex WHERE somethingelse = ?

vs

SELECT something FROM tablex WHERE somethingelse = 4

My understanding is that if only (say) 0.1% of records have 
`somethingelse' = 4 and there's an index on `somethingelse' the planner 
will probably use the index for the second query. For the first query it 
won't know to use the index, especially if there are also values for 
`somethingelse' that occur a lot.

Try running your query in psql/pgadmin using PREPARE and EXECUTE and see 
if you get the same result.

--
Craig Ringer


В списке pgsql-sql по дате отправления:

Предыдущее
От: Steve Crawford
Дата:
Сообщение: Re: Extremely Low performance with ODBC
Следующее
От: "Richard Broersma"
Дата:
Сообщение: Re: Extremely Low performance with ODBC