<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=PostgreSQL%2FSelect_Query%2FEXPLAIN_Query</id>
		<title>PostgreSQL/Select Query/EXPLAIN Query - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=PostgreSQL%2FSelect_Query%2FEXPLAIN_Query"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Select_Query/EXPLAIN_Query&amp;action=history"/>
		<updated>2026-05-26T11:45:02Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=PostgreSQL/Select_Query/EXPLAIN_Query&amp;diff=4898&amp;oldid=prev</id>
		<title> в 13:45, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Select_Query/EXPLAIN_Query&amp;diff=4898&amp;oldid=prev"/>
				<updated>2010-05-26T13:45:56Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 13:45, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://sqle.ru/index.php?title=PostgreSQL/Select_Query/EXPLAIN_Query&amp;diff=4899&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Select_Query/EXPLAIN_Query&amp;diff=4899&amp;oldid=prev"/>
				<updated>2010-05-26T10:14:26Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==A verbose explanation of a simpler query, with the VERBOSE keyword==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# CREATE TABLE employee (&lt;br /&gt;
postgres(#     ID         int,&lt;br /&gt;
postgres(#     name       varchar(10),&lt;br /&gt;
postgres(#     salary     real,&lt;br /&gt;
postgres(#     start_date date,&lt;br /&gt;
postgres(#     city       varchar(10),&lt;br /&gt;
postgres(#     region     char(1)&lt;br /&gt;
postgres(# );&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from employee;&lt;br /&gt;
 id |  name  | salary | start_date |   city    | region&lt;br /&gt;
----+--------+--------+------------+-----------+--------&lt;br /&gt;
  1 | Jason  |  40420 | 1994-02-01 | New York  | W&lt;br /&gt;
  2 | Robert |  14420 | 1995-01-02 | Vancouver | N&lt;br /&gt;
  3 | Celia  |  24020 | 1996-12-03 | Toronto   | W&lt;br /&gt;
  4 | Linda  |  40620 | 1997-11-04 | New York  | N&lt;br /&gt;
  5 | David  |  80026 | 1998-10-05 | Vancouver | W&lt;br /&gt;
  6 | James  |  70060 | 1999-09-06 | Toronto   | N&lt;br /&gt;
  7 | Alison |  90620 | 2000-08-07 | New York  | W&lt;br /&gt;
  8 | Chris  |  26020 | 2001-07-08 | Vancouver | N&lt;br /&gt;
  9 | Mary   |  60020 | 2002-06-09 | Toronto   | W&lt;br /&gt;
(9 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- A verbose explanation of a simpler query, with the VERBOSE keyword:&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# EXPLAIN VERBOSE SELECT * FROM employee;&lt;br /&gt;
                         QUERY PLAN&lt;br /&gt;
-------------------------------------------------------------&lt;br /&gt;
    {SEQSCAN&lt;br /&gt;
    :startup_cost 0.00&lt;br /&gt;
    :total_cost 20.30&lt;br /&gt;
    :plan_rows 1030&lt;br /&gt;
    :plan_width 45&lt;br /&gt;
    :targetlist (&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 1&lt;br /&gt;
          :vartype 23&lt;br /&gt;
          :vartypmod -1&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 1&lt;br /&gt;
          }&lt;br /&gt;
       :resno 1&lt;br /&gt;
       :resname id&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 1&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 2&lt;br /&gt;
          :vartype 1043&lt;br /&gt;
          :vartypmod 14&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 2&lt;br /&gt;
          }&lt;br /&gt;
       :resno 2&lt;br /&gt;
       :resname name&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 2&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 3&lt;br /&gt;
          :vartype 700&lt;br /&gt;
          :vartypmod -1&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 3&lt;br /&gt;
          }&lt;br /&gt;
       :resno 3&lt;br /&gt;
       :resname salary&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 3&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 4&lt;br /&gt;
          :vartype 1082&lt;br /&gt;
          :vartypmod -1&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 4&lt;br /&gt;
          }&lt;br /&gt;
       :resno 4&lt;br /&gt;
       :resname start_date&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 4&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 5&lt;br /&gt;
          :vartype 1043&lt;br /&gt;
          :vartypmod 14&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 5&lt;br /&gt;
          }&lt;br /&gt;
       :resno 5&lt;br /&gt;
       :resname city&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 5&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
       {TARGETENTRY&lt;br /&gt;
       :expr&lt;br /&gt;
          {VAR&lt;br /&gt;
          :varno 1&lt;br /&gt;
          :varattno 6&lt;br /&gt;
          :vartype 1042&lt;br /&gt;
          :vartypmod 5&lt;br /&gt;
          :varlevelsup 0&lt;br /&gt;
          :varnoold 1&lt;br /&gt;
          :varoattno 6&lt;br /&gt;
          }&lt;br /&gt;
       :resno 6&lt;br /&gt;
       :resname region&lt;br /&gt;
       :ressortgroupref 0&lt;br /&gt;
       :resorigtbl 19576&lt;br /&gt;
       :resorigcol 6&lt;br /&gt;
       :resjunk false&lt;br /&gt;
       }&lt;br /&gt;
    )&lt;br /&gt;
    :qual &amp;lt;&amp;gt;&lt;br /&gt;
    :lefttree &amp;lt;&amp;gt;&lt;br /&gt;
    :righttree &amp;lt;&amp;gt;&lt;br /&gt;
    :initPlan &amp;lt;&amp;gt;&lt;br /&gt;
    :extParam (b)&lt;br /&gt;
    :allParam (b)&lt;br /&gt;
    :nParamExec 0&lt;br /&gt;
    :scanrelid 1&lt;br /&gt;
    }&lt;br /&gt;
 Seq Scan on employee  (cost=0.00..20.30 rows=1030 width=45)&lt;br /&gt;
(126 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Executing EXPLAIN for a query==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;sql&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# CREATE TABLE employee (&lt;br /&gt;
postgres(#     ID         int,&lt;br /&gt;
postgres(#     name       varchar(10),&lt;br /&gt;
postgres(#     salary     real,&lt;br /&gt;
postgres(#     start_date date,&lt;br /&gt;
postgres(#     city       varchar(10),&lt;br /&gt;
postgres(#     region     char(1)&lt;br /&gt;
postgres(# );&lt;br /&gt;
ERROR:  relation &amp;quot;employee&amp;quot; already exists&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (1,  &amp;quot;Jason&amp;quot;, 40420,  &amp;quot;02/01/94&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (2,  &amp;quot;Robert&amp;quot;,14420,  &amp;quot;01/02/95&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (3,  &amp;quot;Celia&amp;quot;, 24020,  &amp;quot;12/03/96&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (4,  &amp;quot;Linda&amp;quot;, 40620,  &amp;quot;11/04/97&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (5,  &amp;quot;David&amp;quot;, 80026,  &amp;quot;10/05/98&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (6,  &amp;quot;James&amp;quot;, 70060,  &amp;quot;09/06/99&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (7,  &amp;quot;Alison&amp;quot;,90620,  &amp;quot;08/07/00&amp;quot;, &amp;quot;New York&amp;quot;, &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (8,  &amp;quot;Chris&amp;quot;, 26020,  &amp;quot;07/08/01&amp;quot;, &amp;quot;Vancouver&amp;quot;,&amp;quot;N&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# insert into employee (ID, name,    salary, start_date, city,       region)&lt;br /&gt;
postgres-#               values (9,  &amp;quot;Mary&amp;quot;,  60020,  &amp;quot;06/09/02&amp;quot;, &amp;quot;Toronto&amp;quot;,  &amp;quot;W&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from employee;&lt;br /&gt;
 id |  name  | salary | start_date |   city    | region&lt;br /&gt;
----+--------+--------+------------+-----------+--------&lt;br /&gt;
  1 | Jason  |  40420 | 1994-02-01 | New York  | W&lt;br /&gt;
  2 | Robert |  14420 | 1995-01-02 | Vancouver | N&lt;br /&gt;
  3 | Celia  |  24020 | 1996-12-03 | Toronto   | W&lt;br /&gt;
  4 | Linda  |  40620 | 1997-11-04 | New York  | N&lt;br /&gt;
  5 | David  |  80026 | 1998-10-05 | Vancouver | W&lt;br /&gt;
  6 | James  |  70060 | 1999-09-06 | Toronto   | N&lt;br /&gt;
  7 | Alison |  90620 | 2000-08-07 | New York  | W&lt;br /&gt;
  8 | Chris  |  26020 | 2001-07-08 | Vancouver | N&lt;br /&gt;
  9 | Mary   |  60020 | 2002-06-09 | Toronto   | W&lt;br /&gt;
  1 | Jason  |  40420 | 1994-02-01 | New York  | W&lt;br /&gt;
  2 | Robert |  14420 | 1995-01-02 | Vancouver | N&lt;br /&gt;
  3 | Celia  |  24020 | 1996-12-03 | Toronto   | W&lt;br /&gt;
  4 | Linda  |  40620 | 1997-11-04 | New York  | N&lt;br /&gt;
  5 | David  |  80026 | 1998-10-05 | Vancouver | W&lt;br /&gt;
  6 | James  |  70060 | 1999-09-06 | Toronto   | N&lt;br /&gt;
  7 | Alison |  90620 | 2000-08-07 | New York  | W&lt;br /&gt;
  8 | Chris  |  26020 | 2001-07-08 | Vancouver | N&lt;br /&gt;
  9 | Mary   |  60020 | 2002-06-09 | Toronto   | W&lt;br /&gt;
(18 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- Executing EXPLAIN for a query&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# EXPLAIN SELECT * FROM employee;&lt;br /&gt;
                         QUERY PLAN&lt;br /&gt;
-------------------------------------------------------------&lt;br /&gt;
 Seq Scan on employee  (cost=0.00..20.30 rows=1030 width=45)&lt;br /&gt;
(1 row)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table employee;&lt;br /&gt;
DROP TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=#&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>