diff options
Diffstat (limited to 'doc/src')
-rw-r--r-- | doc/src/FAQ/FAQ_russian.html | 328 |
1 files changed, 191 insertions, 137 deletions
diff --git a/doc/src/FAQ/FAQ_russian.html b/doc/src/FAQ/FAQ_russian.html index e26d33df585..e926c29dc53 100644 --- a/doc/src/FAQ/FAQ_russian.html +++ b/doc/src/FAQ/FAQ_russian.html @@ -12,7 +12,7 @@ <BODY bgcolor="#ffffff" text="#000000" link="#ff0000" vlink="#a00000" alink="#0000ff"> <H1>Ответы на часто задаваемые вопросы по PostgreSQL</H1> - <P>Дата последнего обновления: Пятница 16 сентября 14:07:22 EDT 2005</P> + <P>Дата последнего обновления: Пятница 24 февраля 23:28:40 EDT 2006</P> <P>Английский вариант сопровождает: Брюс Момьян (Bruce Momjian) (<A href= "mailto:pgman@candle.pha.pa.us">pgman@candle.pha.pa.us</A>)<BR> @@ -29,102 +29,102 @@ <HR> <H2 align="center">Общие вопросы</H2> - <A href="#1.1">1.1</A>) Что такое PostgreSQL? Как произносится это название?<BR> - <A href="#1.2">1.2</A>) Каковы авторские права на PostgreSQL?<BR> - <A href="#1.3">1.3</A>) На каких платформах работает PostgreSQL?<BR> - <A href="#1.4">1.4</A>) Где можно взять PostgreSQL?<BR> - <A href="#1.5">1.5</A>) Где получить поддержку?<BR> - <A href="#1.6">1.6</A>) Как мне сообщить об ошибке?<BR> - <A href="#1.7">1.7</A>) Какая версия последняя?<BR> - <A href="#1.8">1.8</A>) Какая документация имеется в наличии?<BR> - <A href="#1.9">1.9</A>) Как найти информацию об известных ошибках или отсутствующих + <A href="#item1.1">1.1</A>) Что такое PostgreSQL? Как произносится это название?<BR> + <A href="#item1.2">1.2</A>) Кто управляет PostgreSQL?<BR> + <A href="#item1.3">1.3</A>) Каковы авторские права на PostgreSQL?<BR> + <A href="#item1.4">1.4</A>) На каких платформах работает PostgreSQL?<BR> + <A href="#item1.5">1.5</A>) Где можно взять PostgreSQL?<BR> + <A href="#item1.6">1.6</A>) Какая версия последняя?<BR> + <A href="#item1.7">1.7</A>) Где получить поддержку?<BR> + <A href="#item1.8">1.8</A>) Как мне сообщить об ошибке?<BR> + <A href="#item1.9">1.9</A>) Как найти информацию об известных ошибках или отсутствующих возможностях?<BR> - <A href="#1.10">1.10</A>) Как научиться <SMALL>SQL</SMALL>?<BR> - <A href="#1.11">1.11</A>) Как присоединится к команде разработчиков?<BR> - <A href="#1.12">1.12</A>) Как сравнивать PostgreSQL с другими + <A href="#item1.10">1.10</A>) Какая документация имеется в наличии?<BR> + <A href="#item1.11">1.11</A>) Как научиться <SMALL>SQL</SMALL>?<BR> + <A href="#item1.12">1.12</A>) Как присоединится к команде разработчиков?<BR> + <A href="#item1.13">1.13</A>) Как сравнить PostgreSQL с другими <SMALL>СУБД</SMALL>?<BR> - <A href="#1.13">1.13</A>) Кто управляет PostgreSQL?<BR> <H2 align="center">Вопросы пользователей по клиентской части</H2> - <A href="#2.1">2.1</A>) Какие интерфейсы есть для PostgreSQL?<BR> - <A href="#2.2">2.2</A>) Какие инструменты существуют для использования + <A href="#item2.1">2.1</A>) Какие интерфейсы есть для PostgreSQL?<BR> + <A href="#item2.2">2.2</A>) Какие инструменты существуют для использования PostgreSQL через Web?<BR> - <A href="#2.3">2.3</A>) Есть ли у PostgreSQL графический интерфейс + <A href="#item2.3">2.3</A>) Есть ли у PostgreSQL графический интерфейс пользователя?<BR> <H2 align="center">Вопросы администрирования</H2> - <A href="#3.1">3.1</A>) Как мне установить PostgreSQL в место отличное + <A href="#item3.1">3.1</A>) Как мне установить PostgreSQL в место отличное от <I>/usr/local/pgsql</I>?<BR> - <A href="#3.2">3.2</A>) Как мне управлять соединениями с других + <A href="#item3.2">3.2</A>) Как мне управлять соединениями от других компьютеров?<BR> - <A href="#3.3">3.3</A>) Какие настройки мне нужно сделать для улучшения + <A href="#item3.3">3.3</A>) Какие настройки мне нужно сделать для улучшения производительности?<BR> - <A href="#3.4">3.4</A>) Какие возможности для отладки есть в наличии?<BR> - <A href="#3.5">3.5</A>) Почему я получаю сообщение <I>"Sorry, too many + <A href="#item3.4">3.4</A>) Какие возможности для отладки есть в наличии?<BR> + <A href="#item3.5">3.5</A>) Почему я получаю сообщение <I>"Sorry, too many clients"</I> когда пытаюсь подключиться к базе?<BR> - <A href="#3.6">3.6</A>) Почему необходимо делать dump и restore при + <A href="#item3.6">3.6</A>) Почему необходимо делать dump и restore при обновлении выпусков PostgreSQL?<BR> - <A href="#3.7">3.7</A>) Какое компьютерное "железо" я должен + <A href="#item3.7">3.7</A>) Какое компьютерное "железо" я должен использовать?<BR> <H2 align="center">Вопросы эксплуатации</H2> - <A href="#4.1">4.1</A>) Как выполнить <SMALL>SELECT</SMALL> только + <A href="#item4.1">4.1</A>) Как выполнить <SMALL>SELECT</SMALL> только для нескольких первых строчек запроса? Для произвольной строки?<BR> - <A href="#4.2">4.2</A>) Как мне найти какие таблицы, индексы, + <A href="#item4.2">4.2</A>) Как мне найти какие таблицы, индексы, базы данных и пользователи существуют? Как мне увидеть запросы, которые использует <I>psql</I> для получения этой информации?<BR> - <A href="#4.3">4.3</A>) Как изменить тип данных колонки?<BR> - <A href="#4.4">4.4</A>) Каковы максимальные размеры для строк в таблице, + <A href="#item4.3">4.3</A>) Как изменить тип данных колонки?<BR> + <A href="#item4.4">4.4</A>) Каковы максимальные размеры для строк в таблице, таблиц и базы данных?<BR> - <A href="#4.5">4.5</A>) Как много дискового пространства в базе данных + <A href="#item4.5">4.5</A>) Как много дискового пространства в базе данных нужно для сохранения данных из обычного текстового файла?<BR> - <A href="#4.6">4.6</A>) Почему мои запросы работают медлено? Почему + <A href="#item4.6">4.6</A>) Почему мои запросы работают медлено? Почему они не используют мои индексы?<BR> - <A href="#4.7">4.7</A>) Как посмотреть на то, как оптимизатор выполняет + <A href="#item4.7">4.7</A>) Как посмотреть на то, как оптимизатор выполняет мой запрос?<BR> - <A href="#4.8">4.8</A>) Как мне выполнить поиск регулярного выражения + <A href="#item4.8">4.8</A>) Как мне выполнить поиск регулярного выражения и поиск независимый от регистра букв поиск регулярного выражения? Как мне использовать индекс для поиска независимого от регистра букв?<BR> - <A href="#4.9">4.9</A>) Как мне определить, что значение поля равно + <A href="#item4.9">4.9</A>) Как мне определить, что значение поля равно <SMALL>NULL</SMALL> в каком-либо запросе? Могу я отсортировать поля <SMALL>NULL</SMALL> или нет?<BR> - <A href="#4.10">4.10</A>) Каковы отличия между разными символьными + <A href="#item4.10">4.10</A>) Каковы отличия между разными символьными типами?<BR> - <A href="#4.11.1">4.11.1</A>) Как мне создать поле serial/с-авто-увеличением?<BR> - <A href="#4.11.2">4.11.2</A>) Как мне получить значение при вставке + <A href="#item4.11.1">4.11.1</A>) Как мне создать поле serial/с-авто-увеличением?<BR> + <A href="#item4.11.2">4.11.2</A>) Как мне получить значение при вставке <SMALL>SERIAL</SMALL>?<BR> - <A href="#4.11.3">4.11.3</A>) Не может ли получиться так, что + <A href="#item4.11.3">4.11.3</A>) Не может ли получиться так, что использование <I>currval()</I> и <I>nextval()</I> приведет к зациклированию с другими пользователями?<BR> - <A href="#4.11.4">4.11.4</A>) Почему числа из моей последовательности + <A href="#item4.11.4">4.11.4</A>) Почему числа из моей последовательности не используются снова при отмене транзакции? Почему создаются разрывы при нумерации в колонке, где я использую последовательность/SERIAL?<BR> - <A href="#4.12">4.12</A>) Что такое <SMALL>OID</SMALL>? Что такое + <A href="#item4.12">4.12</A>) Что такое <SMALL>OID</SMALL>? Что такое <SMALL>CTID</SMALL>?<BR> - <A href="#4.13">4.13</A>) Почему я получаю ошибку <I>"ERROR: Memory + <A href="#item4.13">4.13</A>) Почему я получаю ошибку <I>"ERROR: Memory exhausted in AllocSetAlloc()"</I>?<BR> - <A href="#4.14">4.14</A>) Как мне узнать, какая версия PostgreSQL + <A href="#item4.14">4.14</A>) Как мне узнать, какая версия PostgreSQL запущена?<BR> - <A href="#4.15">4.15</A>) Как мне создать колонку которая по умолчанию + <A href="#item4.15">4.15</A>) Как мне создать колонку которая по умолчанию будет содержать текущее время?<BR> - <A href="#4.16">4.16</A>) Как выполнить внешнее связывание?<BR> - <A href="#4.17">4.17</A>) Как выполнять запросы, использующие несколько + <A href="#item4.16">4.16</A>) Как выполнить внешнее связывание?<BR> + <A href="#item4.17">4.17</A>) Как выполнять запросы, использующие несколько баз данных?<BR> - <A href="#4.18">4.18</A>) Как мне вернуть из функции несколько строк таблицы?<BR> - <A href="#4.19">4.19</A>) Почему я получаю ошибку "relation with OID #### + <A href="#item4.18">4.18</A>) Как мне вернуть из функции несколько строк таблицы?<BR> + <A href="#item4.19">4.19</A>) Почему я получаю ошибку "relation with OID #### не существует", когда обращаютсь к временным таблицам в функциях PL/PgSQL?<BR> - <A href="#4.20">4.20</A>) Какие есть решения для репликации?<BR> - <A href="#4.21">4.21</A>) Почему имена таблицы и колонок не + <A href="#item4.20">4.20</A>) Какие есть решения для репликации?<BR> + <A href="#item4.21">4.21</A>) Почему имена таблицы и колонок не распознаются в в моём запросе?<BR> <HR> <H2 align="center">Общие вопросы</H2> - <H3><A name="1.1">1.1</A>) Что такое PostgreSQL? Как произносится это название?</H3> + <H3><A name="item1.1">1.1</A>) Что такое PostgreSQL? Как произносится это название?</H3> <P>PostgreSQL произносится <I>Post-Gres-Q-L (Пост-Грес-Кью-Эл)</I>, также иногда говорят просто <I>Postgres</I>. Вы можете услышать как @@ -146,18 +146,30 @@ http://www.PostgreSQL.org/files/documentation/faqs/FAQ_DEV.html</A> </P> - <H3><A name="1.2">1.2</A>) Каковы авторские права на PostgreSQL?</H3> + <H3><A name="item1.2">1.2</A>) Кто управляет PostgreSQL?</H3> + + <P>Если вы ищите какого-то особенного человека, центральный + комитет или управляющую компанию, то напрасно --- их нет. + У нас есть ядро комитета и разработчиков, работающих с CVS, + но эти группы служат больше для административных целей, чем + для управления. Проект напрямую функционирует с помощью + сообщества разработчиков и пользователей, к которому может + присоединится каждый. Всё что нужно -- это подписаться на + списки рассылки и участвовать в дискуссиях. (Подробности о + том как включиться в разработку PostgreSQL смотрите в + <a href="http://www.postgresql.org/docs/faqs.FAQ_DEV.html"> + FAQ для разработчиков</A>.)</P> + + <H3><A name="item1.3">1.3</A>) Каковы авторские права на PostgreSQL?</H3> <P>PostgreSQL распространяется по классической лицензии BSD. Эта лицензия не содержит ограничений на то, как будет использоваться исходный код. Нам нравится эта лицензия и у нас нет намерений её - менять.</P> - - <P>Вот эта лицензия BSD, которую мы используем:</P> + менять. Вот эта лицензия BSD, которую мы используем:</P> <P>Система Управления Базами Данных PostgreSQL</P> - <P>Portions copyright (c) 1996-2005, PostgreSQL Global Development + <P>Portions copyright (c) 1996-2006, PostgreSQL Global Development Group Portions Copyright (c) 1994-1996 Regents of the University of California</P> @@ -182,7 +194,7 @@ "КАК ЕСТЬ" И КАЛИФОРНИЙСКИЙ УНИВЕРСИТЕТ НЕ ОБЯЗАН ПРЕДОСТАВЛЯТЬ СОПРОВОЖДЕНИЕ, ПОДДЕРЖКУ, ОБНОВЛЕНИЯ, РАСШИРЕНИЯ ИЛИ ИЗМЕНЕНИЯ.</P> - <H3><A name="1.3">1.3</A>) На каких платформах работает PostgreSQL?</H3> + <H3><A name="item1.4">1.4</A>) На каких платформах работает PostgreSQL?</H3> <P>Обычно, PostgreSQL может работать на любой современной платформе совместимой с Unix. В инструкции по установке, вы найдете список @@ -203,13 +215,22 @@ <A href="http://hobbes.nmsu.edu/cgi-bin/h-search?sh=1&button=Search&key=postgreSQL&stype=all&sort=type&dir=%2F"> http://hobbes.nmsu.edu/cgi-bin/h-search?sh=1&button=Search&key=postgreSQL&stype=all&sort=type&dir=%2F</A>.</P> - <H3><A name="1.4">1.4</A>) Где можно взять PostgreSQL?</H3> + <H3><A name="item1.5">1.5</A>) Где можно взять PostgreSQL?</H3> <P>Через браузер, используя <a href="http://www.postgresql.org/ftp/"> http://www.postgresql.org/ftp/</a> и через ftp, используя <A href="ftp://ftp.PostgreSQL.org/pub/">ftp://ftp.PostgreSQL.org/pub/</A>.</P> - <H3><A name="1.5">1.5</A>) Где получить поддержку?</H3> + + <H3><A name="item1.6">1.6</A>) Какая последняя версия?</H3> + + <P>Последний выпуск PostgreSQL - это версия 8.1.3</P> + + <P>Мы планируем выпускать новые старшие версии каждый год, + а младшие версии каждые несколько месяцев.</P> + + + <H3><A name="item1.7">1.7</A>) Где получить поддержку?</H3> <P>Сообщество PostgreSQL предоставляет помощь множеству пользователей через E-mail. Основной web-сайт для подписки на списки рассылки по @@ -231,26 +252,87 @@ http://techdocs.postgresql.org/companies.php</A>.</P> - <H3><A name="1.6">1.6</A>) Как мне сообщить об ошибке?</H3> + <H3><A name="item1.8">1.8</A>) Как мне сообщить об ошибке?</H3> <P>Посетите страничку со специальной формой отчёта об ошибке в PostgreSQL по адресу: <A HREF="http://www.postgresql.org/support/submitbug"> - http://www.postgresql.org/support/submitbug</A>.</P> - - <P>Также проверьте наличие более свежей версии PostgreSQL на нашем + http://www.postgresql.org/support/submitbug</A>. + Также проверьте наличие более свежей версии PostgreSQL на нашем FTP сайте <A href="ftp://ftp.postgresql.org/pub/"> - ftp://ftp.PostgreSQL.org/pub/</A>. + ftp://ftp.PostgreSQL.org/pub/</A>.</P> + <P>На ошибки, уведомление о которых были сделаны через специальную + форму или отправленные в какой-либо список рассылки PostgreSQL, + обычно генерируется один из следующих ответов:</P> + <UL> + <LI>Это не ошибка и почему</LI> + <LI>Это известная ошибка и она уже есть в списке + <A HREF="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A></LI> + <LI>Данная ошибка была исправлена в текущем выпуске</LI> + <LI>Данная ошибка была исправлена, но исправление пока не попало в + официальный выпуск</LI> + <LI>Запрашивается более детальная информация: + <UL> + <LI>Операционная система</LI> + <LI>Версия PostgreSQL</LI> + <LI>Тест, воспроизводящий ошибку</LI> + <LI>Отладочная информация</LI> + <LI>Вывод backtrace отладчика</LI> + </UL> + </LI> + <LI>Это новая ошибка. Может произойти следующее: + <UL> + <LI>Будет создано исправление, которое будет включено в следующий + выпуск</LI> + <LI>Ошибка не может быть исправлена немедленно и будет добавлена в список + <A HREF="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A></LI> + </UL> + </LI> + </UL> - <H3><A name="1.7">1.7</A>) Какая последняя версия?</H3> + <H3><A name="1.9">1.9</A>) Как найти информацию об известных ошибках + или отсутствующих возможностях?</H3> - <P>Последний выпуск PostgreSQL - это версия 8.0.3</P> + <P>PostgreSQL поддерживает расширенный подкласс <SMALL>SQL:2003</SMALL>. + Смотрите наш список <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A> + на предмет известных ошибок, отсутствующих возможностей и будущих + планов.</P> - <P>Мы планируем выпускать новые старшие версии каждый год, - а младшие версии каждые несколько месяцев.</P> + <P>На запрос какой-либо возможности обычно приходят следующие ответы:</P> + <UL> + <LI>Данная возможность уже есть в списке + <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A></LI> + <LI>Данная возможность нежелательна потому что: + <UL> + <LI>Она дублирует существующую функциональность, которая следует + стандарту SQL</LI> + <LI>Данная возможность сильно усложнила бы код, но дала бы маленькую + выгоду</LI> + <LI>Данная возможность небезопасна или ненадёжна</LI> + </UL> + </LI> + <LI>Данная новая возможность добавлена в список + <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A> + </LI> + </UL> + + <P>PostgreSQL не использует какую-либо систему отслеживания ошибок, + потому что мы обнаружили, что использование прямого обращения по + электронной почте и обновляемого списка + <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A> + является более эффективным. На практике, ошибки в программном + обеспечении сохраняются очень недолго, а ошибки, которые важны + большому количеству пользователей исправляются моментально. Есть + только одно место, где можно найти все изменения, улучшения и + исправления, сделанные в выпуске PostgreSQL - это журналы сообщений + системы контроля версий + <A HREF="http://www.postgresql.org/developer/sourcecode/">CVS</A>. + Даже замечания к выпускам не содержат все изменения, сделанные + в программном обеспечении.</P> + - <H3><A name="1.8">1.8</A>) Какая документация имеется в наличии?</H3> + <H3><A name="item1.10">1.10</A>) Какая документация имеется в наличии?</H3> <P>PostgreSQL содержит много документации, включая большое руководство, страницы электронного руководства man и некоторые маленькие тестовые @@ -274,15 +356,8 @@ <P>Наш сайт содержит еще больше информации.</P> - <H3><A name="1.9">1.9</A>) Как найти информацию об известных ошибках - или отсутствующих возможностях?</H3> - - <P>PostgreSQL поддерживает расширенный подкласс <SMALL>SQL</SMALL>-92. - Смотрите наш список <A href="http://www.postgresql.org/docs/faqs.TODO.html">TODO</A> - на предмет известных ошибок, отсутствующих возможностей и будущих - планов.</P> - <H3><A name="1.10">1.10</A>) Как мне научиться <SMALL>SQL</SMALL>?</H3> + <H3><A name="item1.11">1.11</A>) Как мне научиться <SMALL>SQL</SMALL>?</H3> <P>Во-первых, возьмите одну из книг по PostgreSQL, о которых говорилось выше. Еще один учебник - это книга "Teach Yourself SQL in 21 Days, @@ -301,13 +376,13 @@ и на <A href="http://sqlcourse.com/">http://sqlcourse.com.</A></P> - <H3><A name="1.11">1.11</A>) Как присоединится к команде разработчиков?</H3> + <H3><A name="item1.12">1.12</A>) Как присоединится к команде разработчиков?</H3> <P>Смотрите <a href="http://www.postgresql.org/docs/faqs.FAQ_DEV.html"> FAQ для разработчиков</A>.</P> - <H3><A name="1.12">1.12</A>) Как сравнивать PostgreSQL с другими + <H3><A name="item1.13">1.13</A>) Как сравнить PostgreSQL с другими <SMALL>СУБД</SMALL>?</H3> <P> @@ -359,7 +434,7 @@ пользователей, руководствам и исходным текстам часто делают поддержку PostgreSQL превосходящей другие <SMALL>СУБД</SMALL>. Существует коммерческая поддержка по результам возникших инцидентов, которая - доступна для тех кому она нужна. (Смотрите <A href="#1.5">Секцию 1.5</A>.)<BR> + доступна для тех кому она нужна. (Смотрите <A href="#item1.7">Секцию 1.7</A>.)<BR> <BR> </DD> @@ -373,25 +448,12 @@ </DD> </DL> - <H3><A name="1.13">1.13</A>) Кто управляет PostgreSQL?</H3> - - <P>Если вы ищите какого-то особенного человека, центральный - комитет или управляющую компанию, то напрасно --- их нет. - У нас есть ядро комитета и разработчиков, работающих с CVS, - но эти группы служат больше для административных целей, чем - для управления. Проект напрямую функционирует с помощью - сообщества разработчиков и пользователей, к которому может - присоединится каждый. Всё что нужно -- это подписаться на - списки рассылки и участвовать в дискуссиях. (Подробности о - том как включиться в разработку PostgreSQL смотрите в - <a href="http://www.postgresql.org/docs/faqs.FAQ_DEV.html"> - FAQ для разработчиков</A>.)</P> <HR> <H3 align="center">Вопросы пользователей по клиентской части</H3> - <H3><A name="2.1">2.1</A>) Какие интерфейсы есть для PostgreSQL?</H3> + <H3><A name="item2.1">2.1</A>) Какие интерфейсы есть для PostgreSQL?</H3> <P>Установка PostgreSQL включает только <small>C</small> и встроенный (embedded) <small>C</small> интерфейсы. Все другие интерфейсы @@ -406,7 +468,7 @@ в секции <i>Drivers/Interfaces</I>, а также через поиск в Интернет.</P> - <H3><A name="2.2">2.2</A>) Какие инструменты существуют для использования + <H3><A name="item2.2">2.2</A>) Какие инструменты существуют для использования PostgreSQL через Web?</H3> <P>Прекрасное введение во взаимодействие баз данных и Web можно найти на: @@ -418,7 +480,7 @@ <P>В сложных случаях, многие пользуются Perl и DBD::Pg с CGI.pm или mod_perl.</P> - <H3><A name="2.3">2.3</A>) Есть ли у PostgreSQL графический интерфейс + <H3><A name="item2.3">2.3</A>) Есть ли у PostgreSQL графический интерфейс пользователя?</H3> <P>Да, подробности смотрите в <a href="http://techdocs.postgresql.org/guides/GUITools"> @@ -428,12 +490,12 @@ <H2 align="center">Вопросы администрирования</H2> - <H3><A name="3.1">3.1</A>) Как мне установить PostgreSQL в место отличное + <H3><A name="item3.1">3.1</A>) Как мне установить PostgreSQL в место отличное от <I>/usr/local/pgsql</I>?</H3> <P>Задайте опцию <I>--prefix</I> когда запускаете <I>configure</I>.</P> - <H3><A name="3.2">3.2</A>) Как мне управлять соединениями с других + <H3><A name="item3.2">3.2</A>) Как мне управлять соединениями от других компьютеров?</H3> <P>По умолчанию, PostgreSQL разрешает только соединения на локальной @@ -443,7 +505,7 @@ host-авторизация в файле <I>$PGDATA/pg_hba.conf</I> и перестартовать сервер.</P> - <H3><A name="3.3">3.3</A>) Какие настройки мне нужно сделать для улучшения + <H3><A name="item3.3">3.3</A>) Какие настройки мне нужно сделать для улучшения производительности?</H3> <P>Существует три главных области, которые потенциально могут @@ -495,7 +557,7 @@ </DD> </DL> - <H3><A name="3.4">3.4</A>) Какие возможности для отладки есть в + <H3><A name="item3.4">3.4</A>) Какие возможности для отладки есть в наличии?</H3> <P>Есть множество установок в настройках сервера, начинающихся @@ -504,7 +566,7 @@ и измерения производительности.</P> - <H3><A name="3.5">3.5</A>) Почему я получаю сообщение <I>"Sorry, too + <H3><A name="item3.5">3.5</A>) Почему я получаю сообщение <I>"Sorry, too many clients"</I> когда пытаюсь подключиться к базе?</H3> <P>Вы достигли установленного по умолчанию ограничения на 100 сессий @@ -514,7 +576,7 @@ и перестартовать <I>postmaster</I>.</P> - <H3><A name="3.6">3.6</A>) Почему необходимо делать dump и restore при + <H3><A name="item3.6">3.6</A>) Почему необходимо делать dump и restore при обновлении выпусков PostgreSQL?</H3> <P>Разработчики PostgreSQL делают только небольшие изменения между @@ -533,7 +595,7 @@ использовать <i>pg_upgrade</i> для этого выпуска.</P> - <H3><A name="3.7">3.7</A>) Какое компьютерное "железо" я должен + <H3><A name="item3.7">3.7</A>) Какое компьютерное "железо" я должен использовать?</H3> <P>Поскольку "железо" персональных компьютеров является наиболее @@ -549,7 +611,7 @@ <H2 align="center">Вопросы эксплуатации</H2> - <H3><A name="4.1">4.1</A>) Как выполнить <SMALL>SELECT</SMALL> только + <H3><A name="item4.1">4.1</A>) Как выполнить <SMALL>SELECT</SMALL> только для нескольких первых строчек запроса? Произвольной строки?</H3> <P>Для получения только нескольких строк, если вы знаете их количество @@ -567,7 +629,7 @@ </PRE> - <H3><A name="4.2">4.2</A>) Как мне найти какие таблицы, индексы, + <H3><A name="item4.2">4.2</A>) Как мне найти какие таблицы, индексы, базы данных и пользователи существуют? Как мне увидеть запросы, которые использует <I>psql</I> для получения этой информации?</H3> @@ -592,7 +654,7 @@ для получения информации из системных таблиц базы данных.</P> - <H3><A name="4.3">4.3</A>) Как изменить тип данных колонки?</H3> + <H3><A name="item4.3">4.3</A>) Как изменить тип данных колонки?</H3> <P>В 8.0 и более поздних версиях, изменение типа колонки выполняется очень легко через <SMALL>ALTER TABLE ALTER COLUMN TYPE</SMALL>.</P> @@ -606,7 +668,7 @@ COMMIT; </PRE> - <H3><A name="4.4">4.4</A>) Каковы максимальные размеры для строк в таблице, + <H3><A name="item4.4">4.4</A>) Каковы максимальные размеры для строк в таблице, таблиц и базы данных?</H3> <P>Существуют следующие ограничения:</P> @@ -663,7 +725,7 @@ с помощью функционального индекса из хэша MD5 длинной колонки, а полнотекстовое индексирование позволяет искать слова внутри колонки.</P> - <H3><A name="4.5">4.5</A>) Как много дискового пространства в базе данных + <H3><A name="item4.5">4.5</A>) Как много дискового пространства в базе данных нужно для сохранения данных из обычного текстового файла?</H3> <P>СУБД PostgreSQL может потребоваться дискового пространства до 5 раз @@ -673,7 +735,7 @@ которых целое число и текстовое описание. При этом длина текста, в среднем, составляет 20 байт. Размер простого файла составит 2.8 MB. Размер базы PostgreSQL, содержащей эти же данные составит приблизительно - 6.4 MB из которых:</P> + 5.6 MB из которых:</P> <PRE> 28 байт: на каждый заголовок строки в таблице (приблизительно) + 24 байта: одно поле с целочисленным типом и одно текстовое поле @@ -701,7 +763,7 @@ занимают очень мало места. </P> - <H3><A name="4.6">4.6</A>) Почему мои запросы работают медлено? Почему + <H3><A name="item4.6">4.6</A>) Почему мои запросы работают медлено? Почему они не используют мои индексы?</H3> <P>Индексы не используются для каждого запроса. Они @@ -726,15 +788,7 @@ сортировкой обычно быстрее, чем поиск по индексам в большой таблице. Однако, <SMALL>ORDER BY</SMALL> часто комбинируется с <SMALL>LIMIT</SMALL> и в этом случае индекс будет использоваться, поскольку при выполнении - будет возвращаться небольшая часть таблицы. Фактически MAX() и MIN() не - используют индексы, но индекс используется при построении запросов с - <SMALL>ORDER BY</SMALL> и <SMALL>LIMIT</SMALL>: -<PRE> - SELECT col - FROM tab - ORDER BY col [ DESC ] - LIMIT 1; -</PRE> + будет возвращаться небольшая часть таблицы.</P> <P>Если вам кажется, что оптимизатор некорректно выбирает последовательный перебор, используйте <CODE>SET enable_seqscan TO 'off'</CODE> и @@ -753,7 +807,7 @@ <LI>Строка поиска не должна начинаться с символа класса, т.е. [a-e].</LI> <LI>Поиск независимый от регистра, такой как <small>ILIKE</small> и <i>~*</i> не использует индексы. Вместо него, используйте индексы - выражений, которые описываются в секции <A href="#4.8">4.8</A>.</LI> + выражений, которые описываются в секции <A href="#item4.8">4.8</A>.</LI> <LI>Во время <i>initdb</i> должна использоваться локаль по умолчанию <i>C</i>, потому что не существует возможности узнать следующий наибольший символ для не-C локали. Вы можете для таких случаев создать специальный @@ -765,13 +819,13 @@ если типы данных точно не совпадали с индексными типами колонок. Это особенно касалось int2, int8 и numeric индексов колонок.</P> - <H3><A name="4.7">4.7</A>) Как посмотреть на то, как оптимизатор выполняет + <H3><A name="item4.7">4.7</A>) Как посмотреть на то, как оптимизатор выполняет мой запрос?</H3> <P>Смотрите страницу руководства посвященную <SMALL>EXPLAIN</SMALL>.</P> - <H3><A name="4.8">4.8</A>) Как мне выполнить поиск регулярного выражения + <H3><A name="item4.8">4.8</A>) Как мне выполнить поиск регулярного выражения и поиск независимый от регистра букв поиск регулярного выражения? Как мне использовать индекс для поиска независимого от регистра букв?</H3> @@ -799,7 +853,7 @@ только в определённом регистре, используйте ограничение <SMALL>CHECK</SMALL> или проверку через триггер.</P> - <H3><A name="4.9">4.9</A>) Как мне определить, что значение поля равно + <H3><A name="item4.9">4.9</A>) Как мне определить, что значение поля равно <SMALL>NULL</SMALL> в каком-либо запросе? Могу я отсортировать поля <SMALL>NULL</SMALL> или нет?</H3> @@ -823,7 +877,7 @@ ORDER BY (col IS NOT NULL); </PRE> - <H3><A name="4.10">4.10</A>) Каковы отличия между разными символьными + <H3><A name="item4.10">4.10</A>) Каковы отличия между разными символьными типами?</H3> <BLOCKQUOTE> <TABLE> @@ -882,7 +936,7 @@ которых могут включать <SMALL>NULL</SMALL> байты. Все типы описанные здесь, имеют сходные характеристики производительности.</P> - <H3><A name="4.11.1">4.11.1</A>) Как мне создать поле + <H3><A name="item4.11.1">4.11.1</A>) Как мне создать поле serial/с-авто-увеличением?</H3> <P>PostgreSQL поддерживает тип данных <SMALL>SERIAL</SMALL>. Он @@ -906,13 +960,13 @@ Смотрите подробности о последовательностях на странице руководства посвященной <I>create_sequence</I>. - <H3><A name="4.11.2">4.11.2</A>) Как мне получить значение при вставке + <H3><A name="item4.11.2">4.11.2</A>) Как мне получить значение при вставке <SMALL>SERIAL</SMALL>?</H3> <P>Один из способов состоит в получении следующего значения <SMALL>SERIAL</SMALL> из объекта sequence с помощью функции <I>nextval()</I> <I>перед</I> вставкой и затем вставлять это значение - явно. Используйте таблицу-пример в <A href="#4.11.1">4.11.1</A>, пример + явно. Используйте таблицу-пример в <A href="#item4.11.1">4.11.1</A>, пример в псевдоязыке покажет как это делается:</P> <PRE> new_id = execute("SELECT nextval('person_id_seq')"); @@ -936,14 +990,14 @@ </PRE> - <H3><A name="4.11.3">4.11.3</A>) Не может ли получиться так, что + <H3><A name="item4.11.3">4.11.3</A>) Не может ли получиться так, что использование <I>currval()</I> и <I>nextval()</I> приведет к зациклированию с другими пользователями?</H3> <P>Нет. <i>currval()</i> возвращает текущее значение, назначенное вашей сессией, а не другими сессиями.</P> - <H3><A name="4.11.4">4.11.4</A>) Почему числа из моей последовательности + <H3><A name="item4.11.4">4.11.4</A>) Почему числа из моей последовательности не используются снова при отмене транзакции? Почему создаются разрывы при нумерации в колонке, где я использую последовательность/SERIAL?</H3> @@ -953,7 +1007,7 @@ нумерации при отмене транзакций.</P> - <H3><A name="4.12">4.12</A>) Что такое <SMALL>OID</SMALL>? Что такое + <H3><A name="item4.12">4.12</A>) Что такое <SMALL>OID</SMALL>? Что такое <SMALL>CTID</SMALL>?</H3> <P>Каждая, создаваемая в PostgreSQL табличная строка, получает уникальный @@ -978,7 +1032,7 @@ указателя на физические записи.</P> - <H3><A name="4.13">4.13</A>) Почему я получаю ошибку <I>"ERROR: Memory + <H3><A name="item4.13">4.13</A>) Почему я получаю ошибку <I>"ERROR: Memory exhausted in AllocSetAlloc()"</I>?</H3> <P>Предположительно у вас закончилась виртуальная память @@ -998,13 +1052,13 @@ клиентом, потому что backend возвращает слишком большой объем данных, попытайтесь выполнить эту команду перед запуском клиента. - <H3><A name="4.14">4.14</A>) Как мне узнать, какая версия PostgreSQL + <H3><A name="item4.14">4.14</A>) Как мне узнать, какая версия PostgreSQL запущена?</H3> <P>Из <I>psql</I>, наберите <CODE>SELECT version();</CODE></P> - <H3><A name="4.15">4.15</A>) Как мне создать колонку которая по умолчанию + <H3><A name="item4.15">4.15</A>) Как мне создать колонку которая по умолчанию будет содержать текущее время?</H3> <P>Используйте <I>CURRENT_TIMESTAMP</I>:</P> @@ -1012,7 +1066,7 @@ CREATE TABLE test (x int, modtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); </PRE> - <H3><A name="4.16">4.16</A>) Как мне выполнить внешнее связывание?</H3> + <H3><A name="item4.16">4.16</A>) Как мне выполнить внешнее связывание?</H3> <P>PostgreSQL поддерживает внешнее связывание, используя стандартный синтаксис SQL. Вот два примера:</P> @@ -1036,7 +1090,7 @@ CREATE TABLE test (x int, modtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); <SMALL>RIGHT</SMALL> и <SMALL>FULL</SMALL> связываниях. Обычные связывания называются <SMALL>INNER</SMALL> связывания.</P> - <H3><A name="4.17">4.17</A>) Как выполнять запросы, использующие несколько + <H3><A name="item4.17">4.17</A>) Как выполнять запросы, использующие несколько баз данных?</H3> <P>Не существует способа создать запрос к базам данных отличным от текущей. @@ -1048,14 +1102,14 @@ CREATE TABLE test (x int, modtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); соедиенения с различными базами данных и таких образом объединять информацию из них.</P> - <H3><A name="4.18">4.18</A>) Как мне вернуть из функции несколько строк таблицы?</H3> + <H3><A name="item4.18">4.18</A>) Как мне вернуть из функции несколько строк таблицы?</H3> <P>Вы можете легко использовать функции, возвращающие список, <A href="http://techdocs.postgresql.org/guides/SetReturningFunctions"> http://techdocs.postgresql.org/guides/SetReturningFunctions</A>.</P> - <H3><A name="4.19">4.19</A>) Почему я получаю ошибку "relation with OID #### + <H3><A name="item4.19">4.19</A>) Почему я получаю ошибку "relation with OID #### не существует", когда обращаютсь к временным таблицам в функциях PL/PgSQL?</H3> <P>PL/PgSQL кэширует сценарии функции и один из негативных эффектов этого @@ -1068,7 +1122,7 @@ CREATE TABLE test (x int, modtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); перегенерироваться каждый раз.</P> - <H3><A name="4.20">4.20</a>) Какие есть решения для репликации?</H3> + <H3><A name="item4.20">4.20</a>) Какие есть решения для репликации?</H3> <P>Хотя "репликация" -- это единый термин, есть несколько разных технологий для выполнения репликаций с разными особенностями для каждой.</P> @@ -1088,7 +1142,7 @@ CREATE TABLE test (x int, modtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); популярным решением для такой репликации в PostgreSQL является <A href="http://pgfoundry.org/projects/pgcluster/">Pgcluster</A>. - <H3><A name="4.21">4.21</A>) Почему имена таблицы и колонок не + <H3><A name="item4.21">4.21</A>) Почему имена таблицы и колонок не распознаются в в моём запросе?</H3> <P>Наиболее часто это происходит из-за использования двойных кавычек в |