<?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%2FArray%2FArray_Column_Update</id>
		<title>PostgreSQL/Array/Array Column Update - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://sqle.ru/index.php?action=history&amp;feed=atom&amp;title=PostgreSQL%2FArray%2FArray_Column_Update"/>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Array/Array_Column_Update&amp;action=history"/>
		<updated>2026-04-06T03:39:10Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://sqle.ru/index.php?title=PostgreSQL/Array/Array_Column_Update&amp;diff=5004&amp;oldid=prev</id>
		<title> в 13:45, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Array/Array_Column_Update&amp;diff=5004&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/Array/Array_Column_Update&amp;diff=5005&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://sqle.ru/index.php?title=PostgreSQL/Array/Array_Column_Update&amp;diff=5005&amp;oldid=prev"/>
				<updated>2010-05-26T10:14:35Z</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;==An array may also be updated at a single element==&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=#&lt;br /&gt;
postgres=# CREATE TABLE sal_emp (&lt;br /&gt;
postgres(#    name            text,&lt;br /&gt;
postgres(#    pay_by_quarter  integer[],&lt;br /&gt;
postgres(#    schedule        text[][]&lt;br /&gt;
postgres(# );&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Bill&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[10000, 10000, 10000, 10000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;], [&amp;quot;training&amp;quot;, &amp;quot;presentation&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Carol&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[20000, 25000, 25000, 25000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;breakfast&amp;quot;, &amp;quot;consulting&amp;quot;], [&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT * FROM sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- An array may also be updated at a single element:&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE sal_emp SET pay_by_quarter[4] = 15000 WHERE name = &amp;quot;Bill&amp;quot;;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
 Bill  | {10000,10000,10000,15000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table sal_emp;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==An array value can be replaced completely==&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=#&lt;br /&gt;
postgres=# CREATE TABLE sal_emp (&lt;br /&gt;
postgres(#    name            text,&lt;br /&gt;
postgres(#    pay_by_quarter  integer[],&lt;br /&gt;
postgres(#    schedule        text[][]&lt;br /&gt;
postgres(# );&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Bill&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[10000, 10000, 10000, 10000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;], [&amp;quot;training&amp;quot;, &amp;quot;presentation&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Carol&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[20000, 25000, 25000, 25000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;breakfast&amp;quot;, &amp;quot;consulting&amp;quot;], [&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT * FROM sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- An array value can be replaced completely:&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE sal_emp SET pay_by_quarter = &amp;quot;{25000,25000,27000,27000}&amp;quot; WHERE name = &amp;quot;Carol&amp;quot;;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT * FROM sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {25000,25000,27000,27000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table sal_emp;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Modifying an array subscript==&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 book (id integer,titles text[]);&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO book VALUES (102, &amp;quot;{&amp;quot;AAA\&amp;quot;s VVVV&amp;quot;}&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# INSERT INTO book VALUES (103, &amp;quot;{&amp;quot;AAA&amp;quot;, &amp;quot;VVVV&amp;quot;}&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- Modifying an array subscript&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE book&lt;br /&gt;
postgres-#         SET titles[1] = &amp;quot;New\&amp;quot;s New&amp;quot;&lt;br /&gt;
postgres-#         WHERE titles[1] = &amp;quot;AAA&amp;quot;;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT titles[1] FROM book;&lt;br /&gt;
   titles&lt;br /&gt;
------------&lt;br /&gt;
 AAA&amp;quot;s VVVV&lt;br /&gt;
 New&amp;quot;s New&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table book;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Update array value==&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=# CREATE TABLE book (id integer,titles text[]);&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO book VALUES (102, &amp;quot;{&amp;quot;AAA\&amp;quot;s VVVV&amp;quot;}&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=# INSERT INTO book VALUES (103, &amp;quot;{&amp;quot;AAA&amp;quot;, &amp;quot;VVVV&amp;quot;}&amp;quot;);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from book;&lt;br /&gt;
 id  |     titles&lt;br /&gt;
-----+----------------&lt;br /&gt;
 102 | {&amp;quot;AAA&amp;quot;s VVVV&amp;quot;}&lt;br /&gt;
 103 | {AAA,VVVV}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE book&lt;br /&gt;
postgres-#         SET titles=&amp;quot;{&amp;quot;AAA\&amp;quot;s VVV&amp;quot;,&amp;quot;ABC&amp;quot;}&amp;quot;&lt;br /&gt;
postgres-#         WHERE id = 102;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from book;&lt;br /&gt;
 id  |      titles&lt;br /&gt;
-----+-------------------&lt;br /&gt;
 103 | {AAA,VVVV}&lt;br /&gt;
 102 | {&amp;quot;AAA&amp;quot;s VVV&amp;quot;,ABC}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table book;&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;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Update in a slice==&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=#&lt;br /&gt;
postgres=# CREATE TABLE sal_emp (&lt;br /&gt;
postgres(#    name            text,&lt;br /&gt;
postgres(#    pay_by_quarter  integer[],&lt;br /&gt;
postgres(#    schedule        text[][]&lt;br /&gt;
postgres(# );&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Bill&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[10000, 10000, 10000, 10000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;], [&amp;quot;training&amp;quot;, &amp;quot;presentation&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Carol&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[20000, 25000, 25000, 25000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;breakfast&amp;quot;, &amp;quot;consulting&amp;quot;], [&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT * FROM sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- Update in a slice:&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE sal_emp SET pay_by_quarter[1:2] = &amp;quot;{27000,27000}&amp;quot; WHERE name = &amp;quot;Carol&amp;quot;;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {27000,27000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table sal_emp;&lt;br /&gt;
DROP TABLE&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;
==Using the ARRAY expression syntax==&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=#&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# CREATE TABLE sal_emp (&lt;br /&gt;
postgres(#    name            text,&lt;br /&gt;
postgres(#    pay_by_quarter  integer[],&lt;br /&gt;
postgres(#    schedule        text[][]&lt;br /&gt;
postgres(# );&lt;br /&gt;
CREATE TABLE&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Bill&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[10000, 10000, 10000, 10000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;], [&amp;quot;training&amp;quot;, &amp;quot;presentation&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# INSERT INTO sal_emp&lt;br /&gt;
postgres-#    VALUES (&amp;quot;Carol&amp;quot;,&lt;br /&gt;
postgres(#    ARRAY[20000, 25000, 25000, 25000],&lt;br /&gt;
postgres(#    ARRAY[[&amp;quot;breakfast&amp;quot;, &amp;quot;consulting&amp;quot;], [&amp;quot;meeting&amp;quot;, &amp;quot;lunch&amp;quot;]]);&lt;br /&gt;
INSERT 0 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# SELECT * FROM sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {20000,25000,25000,25000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# -- using the ARRAY expression syntax:&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# UPDATE sal_emp SET pay_by_quarter = ARRAY[25000,25000,27000,27000] WHERE name = &amp;quot;Carol&amp;quot;;&lt;br /&gt;
UPDATE 1&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# select * from sal_emp;&lt;br /&gt;
 name  |      pay_by_quarter       |                 schedule&lt;br /&gt;
-------+---------------------------+-------------------------------------------&lt;br /&gt;
 Bill  | {10000,10000,10000,10000} | {{meeting,lunch},{training,presentation}}&lt;br /&gt;
 Carol | {25000,25000,27000,27000} | {{breakfast,consulting},{meeting,lunch}}&lt;br /&gt;
(2 rows)&lt;br /&gt;
postgres=#&lt;br /&gt;
postgres=# drop table sal_emp;&lt;br /&gt;
DROP TABLE&lt;br /&gt;
postgres=#&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>