Whether you need something simple, like a shopping list, or complex,
like a color swatch generator, PostgreSQL commands make it easy.
![Team checklist and to dos][1]
In _[Getting started with PostgreSQL][2]_, I explained how to install, set up, and begin using the open source database software. But there's a lot more you can do with commands in[PostgreSQL][3].
For example, I use Postgres to keep track of my grocery shopping list. I do most of the grocery shopping in our home, andthe bulk of it happens once a week. I go to several places to buy the things on my list because each store offers a particular selection or quality or maybe a better price. Initially, I made an HTML form page to manage my shopping list, but itcouldn't save my entries. So, I hadto wait to make my list all at once, and by then I usually forgot some items we need or I want.
Instead, with PostgreSQL, I can enter bits when I think of them as the week goes onand print out the whole thing right before I go shopping. Here's how you can do that, too.
### Create a simple shopping list
First, enter the database with the**psql**command, then create a table for yourlist with:
Type commands like the following to add items to your list:
```
insert into groc values ('milk', 'K');
insert into groc values ('bananas', 'KW');
```
There are two pieces of information (separated by a comma) inside the parentheses: the item youwant to buy and letters indicating where you want to buy it and whether it's something you usuallybuy every week(W).
Since **psql** has a history, youcan press the Up arrow and edit the data between the parentheses instead of having to type the whole line for each item.
After entering a handful of items, check what you've entered with:
```
Select * from groc order by comment;
item | comment
\----------------+---------
ground coffee | H
butter | K
chips | K
steak | K
milk | K
bananas | KW
raisin bran | KW
raclette | L
goat cheese | L
onion | P
oranges | P
potatoes | P
spinach | PW
broccoli | PW
asparagus | PW
cucumber | PW
sugarsnap peas | PW
salmon | S
(18 rows)
```
This command orders theresults by the _comment_ column so that the items are grouped by where you buy them to make it easier to shop.
By using a W to indicateyour weekly purchases, you cankeep yourweekly items on the list when you clear out the table to preparefor the next week's list. To so that, enter:
```
`delete from groc where comment not like '%W';`
```
Notice that in PostgreSQL, **%** is the wildcard character (instead of an asterisk). So, to save typing, youmight type:
```
`delete from groc where item like 'goat%';`
```
You can't use **item = 'goat%'**; it won't work.
When you're ready to shop, output your list to print it or send it to your phone with:
```
\o groclist.txt
select * from groc order by comment;
\o
```
The last command, **\o**, with nothing afterward, resets the output to the command line. Otherwise, all output will continue to go to thegroc file you created.
### Analyze complex tables
This item-by-item entry may be okay for short tables, but what about really big ones? A couple of years ago, I was helping the team at [FreieFarbe.de][4]to create aswatchbook of the free colors (freieFarbe means "free colors"in German)from its HLC color palette, where virtually any imaginable print color can be specified by its hue, luminosity (brightness), and chroma (saturation).The result was the [HLC Color Atlas][5], and here's how we did it.
The teamsent me files with color specifications so I could write Python scripts that would work with Scribus to generate the swatchbooks of color patches easily. One example started like:
```
HLC, C, M, Y, K
H010_L15_C010, 0.5, 49.1, 0.1, 84.5
H010_L15_C020, 0.0, 79.7, 15.1, 78.9
H010_L25_C010, 6.1, 38.3, 0.0, 72.5
H010_L25_C020, 0.0, 61.8, 10.6, 67.9
H010_L25_C030, 0.0, 79.5, 18.5, 62.7
H010_L25_C040, 0.4, 94.2, 17.3, 56.5
H010_L25_C050, 0.0, 100.0, 15.1, 50.6
H010_L35_C010, 6.1, 32.1, 0.0, 61.8
H010_L35_C020, 0.0, 51.7, 8.4, 57.5
H010_L35_C030, 0.0, 68.5, 17.1, 52.5
H010_L35_C040, 0.0, 81.2, 22.0, 46.2
H010_L35_C050, 0.0, 91.9, 20.4, 39.3
H010_L35_C060, 0.1, 100.0, 17.3, 31.5
H010_L45_C010, 4.3, 27.4, 0.1, 51.3
```
This is slightly modified from the original, which separated the data with tabs. I transformed it into a CSV (comma-separated value) file, which I prefer to use with Python. (CSV files are also very useful because they can be imported easily into a spreadsheet program.)
In each line, the first item is the color name, and it's followed by its C, M, Y, and K color values. The file consisted of 1,793 colors, and I wanted a way to analyze the information to get a sense of the range of values. This is where PostgreSQL comes into play. I did not want to enter all of this data manually—I don't think I could without errors (and headaches). Fortunately, PostgreSQL has a command for this.
My first step was to create the database with:
```
`Create table hlc_cmyk (color varchar(40), c decimal, m decimal, y decimal, k decimal);`
```
Then I brought in the data with:
```
`\copy hlc_cmyk from '/home/gregp/HLC_Atlas_CMYK_SampleData.csv' with (header, format CSV);`
```
The backslash at the beginning is there because using the plain **copy** command is restricted to root and the Postgres superuser. In the parentheses, **header** means the first line contains headings and shouldbe ignored, and **CSV** means the file format is CSV. Note that parentheses are not required around the color name in this method.
If the operation is successful, I see a message that says**COPY NNNN**, where the N's refer to the number of rows inserted into the table.
Finally, I can query the table with:
```
select * from hlc_cmyk;
color | c | m | y | k
\---------------+-------+-------+-------+------
H010_L15_C010 | 0.5 | 49.1 | 0.1 | 84.5
H010_L15_C020 | 0.0 | 79.7 | 15.1 | 78.9
H010_L25_C010 | 6.1 | 38.3 | 0.0 | 72.5
H010_L25_C020 | 0.0 | 61.8 | 10.6 | 67.9
H010_L25_C030 | 0.0 | 79.5 | 18.5 | 62.7
H010_L25_C040 | 0.4 | 94.2 | 17.3 | 56.5
H010_L25_C050 | 0.0 | 100.0 | 15.1 | 50.6
H010_L35_C010 | 6.1 | 32.1 | 0.0 | 61.8
H010_L35_C020 | 0.0 | 51.7 | 8.4 | 57.5
H010_L35_C030 | 0.0 | 68.5 | 17.1 | 52.5
```
It goes on like this for all 1,793 rows of data. In retrospect, I can't say that this query was absolutely necessary for the HLC and Scribus task, but it allayed some of my anxieties about the project.
To generate the HLC Color Atlas,I automated creating the color charts with Scribus for the 13,000+ colors in those pages of color swatches.
I could have used the **copy** command to output my data:
```
`\copy hlc_cmyk to '/home/gregp/hlc_cmyk_backup.csv' with (header, format CSV);`
```
I also could restrict the output according to certain values with a **where** clause.
For example, the following commandwill only send the table values for the hues that begin with H10.
```
`\copy hlc_cmyk to '/home/gregp/hlc_cmyk_backup.csv' with (header, format CSV) where color like 'H10%';`
```
### Back up or transfer adatabase or table
The final command I will mention here is **pg_dump**, which is used to back up a PostgreSQL database andruns outside of the **psql** console. For example:
```
pg_dump gregp -t hlc_cmyk > hlc.out
pg_dump gregp > dball.out
```
The first line exports the **hlc_cmyk** table along with its structure. The second line dumps all the tables inside the **gregp** database. This is very useful for backing up or transferringa database or tables.
To transfer a database or tableto another computer, first, create a database on the other computer (see my "[getting started][2]" article for details), then do the reverse process:
```
`psql -d gregp -f dball.out`
```
This creates all the tables and enters the data in one step.
### Conclusion
In this article, we have seen how to use the **WHERE** parameter to restrict operations, along with the use of the PostgreSQL wildcard character **%**. We've also seen how to load a large amount of data into a table, then output some or all of the table data to a file, or even your entire database with all its individual tables.
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/todo_checklist_team_metrics_report.png?itok=oB5uQbzf (Team checklist and to dos)