--- title: 'PostgreSQL Tutorial' page_title: 'PostgreSQL Tutorial' page_description: 'Learn PostgreSQL quickly through a practical PostgreSQL tutorial designed for database administrators and application developers.' prev_url: 'https://www.postgresqltutorial.com/' ogImage: '/postgresqltutorial/postgresql-tutorial-homepage.svg' updatedOn: '2024-09-08T01:42:12+00:00' enableTableOfContents: true --- ![PostgreSQL Tutorial](/postgresqltutorial/postgresql-tutorial-homepage.svg?alignright 'PostgreSQL Tutorial') Welcome to the PostgreSQLTutorial.com website! This **PostgreSQL tutorial** helps you quickly understand PostgreSQL. You’ll master PostgreSQL fast through many practical examples and apply the knowledge to application development using PostgreSQL. If you want to: - Learn PostgreSQL fast. - Develop applications using PostgreSQL as the back\-end database. - Migrate from other database management systems such as MySQL, Oracle, and Microsoft SQL Server. You’ve come to the right place. This website provides you with everything you need to know to get started with PostgreSQL quickly and effectively. The PostgreSQL tutorial demonstrates many unique features of PostgreSQL that position it as the most advanced open\-source database management system. ## Quick start ![](/postgresqltutorial/getting-started-with-postgresql.svg?alignleft) [Getting Started with PostgreSQL](./postgresql-getting-started/) This section helps you get started with PostgreSQL by showing you how to install PostgreSQL on Windows, Linux, and macOS. You also learn how to connect to PostgreSQL using the `psql` tool as well as how to load a sample database into the PostgreSQL for practicing. ## Basic Tutorial First, you’ll learn how to query data from a single table using basic data techniques, which include selecting data, sorting result sets, and filtering rows. Next, you’ll delve into advanced queries, which include joining multiple tables, using set operations, and constructing the subquery. Finally, you’ll learn how to manage database tables, including creating a new table or modifying the structure of an existing table. ### Section 1\. Querying Data - [Select](./postgresql-tutorial/postgresql-select/ 'PostgreSQL SELECT') – show you how to query data from a single table. - [Column aliases](./postgresql-tutorial/postgresql-column-alias/) – learn how to assign temporary names to columns or expressions within a query. - [Order By](./postgresql-tutorial/postgresql-order-by/ 'PostgreSQL ORDER BY') – guide you on how to sort the result set returned by a query. - [Select Distinct](./postgresql-tutorial/postgresql-select-distinct/ 'PostgreSQL SELECT DISTINCT')  – show you how to remove duplicate rows from the result set. ### Section 2\. Filtering Data - [Where](./postgresql-tutorial/postgresql-where/ 'PostgreSQL WHERE') – filter rows based on a specified condition. - [AND operator](./postgresql-tutorial/postgresql-and/) – combine two boolean expressions and return true if both expressions evaluate to true. - [OR operator](./postgresql-tutorial/postgresql-or/) – combine two boolean expressions and return false if either expression evaluates to false. - [Limit](./postgresql-tutorial/postgresql-limit/) – retrieve a subset of rows generated by a query. - [Fetch](./postgresql-tutorial/postgresql-fetch/)– limit the number of rows returned by a query. - [In](./postgresql-tutorial/postgresql-in/ 'PostgreSQL IN') – select data that matches any value in a list of values. - [Between](./postgresql-tutorial/postgresql-between/ 'PostgreSQL BETWEEN') – select data that is a range of values. - [Like](./postgresql-tutorial/postgresql-like/ 'PostgreSQL LIKE') – filter data based on pattern matching. - [Is Null](./postgresql-tutorial/postgresql-is-null/) – check if a value is null or not. ### Section 3\. Joining Multiple Tables - [Joins](./postgresql-tutorial/postgresql-joins/) – show you a brief overview of joins in PostgreSQL. - [Table aliases](./postgresql-tutorial/postgresql-alias/) – describes how to use table aliases in the query. - [Inner Join](./postgresql-tutorial/postgresql-inner-join/ 'PostgreSQL INNER JOIN')– select rows from one table that have the corresponding rows in other tables. - [Left Join](./postgresql-tutorial/postgresql-left-join/ 'PostgreSQL LEFT JOIN') – select rows from one table that may or may not have the corresponding rows in other tables. - [Self\-join](./postgresql-tutorial/postgresql-self-join/) – join a table to itself by comparing a table to itself. - [Full Outer Join](./postgresql-tutorial/postgresql-full-outer-join/) – use the full join to find a row in a table that does not have a matching row in another table. - [Cross Join](./postgresql-tutorial/postgresql-cross-join/) – produce a Cartesian product of the rows in two or more tables. - [Natural Join](./postgresql-tutorial/postgresql-natural-join/) – join two or more tables using implicit join conditions based on the common column names in the joined tables. ### Section 4\. Grouping Data - [Group By](./postgresql-tutorial/postgresql-group-by/ 'PostgreSQL GROUP BY') – divide rows of a result set into groups and optionally apply an aggregate function to each group. - [Having](./postgresql-tutorial/postgresql-having/ 'PostgreSQL HAVING') – apply conditions to groups, which allow you to filter groups. ### Section 5\. Set Operations - [Union](./postgresql-tutorial/postgresql-union/ 'PostgreSQL UNION') – combine result sets of multiple queries into a single result set. - [Intersect](./postgresql-tutorial/postgresql-intersect/) – combine the result sets of two or more queries and return a single result set containing rows that appear in both result sets. - [Except](./postgresql-tutorial/postgresql-except/) – return the rows from the first query that do not appear in the output of the second query. ### Section 6\. Grouping sets, Cubes, and Rollups - [Grouping Sets](./postgresql-tutorial/postgresql-grouping-sets/)  – generate multiple grouping sets in reporting. - [Cube](./postgresql-tutorial/postgresql-cube/) – define multiple grouping sets that include all possible combinations of dimensions. - [Rollup](./postgresql-tutorial/postgresql-rollup/) – generate reports that contain totals and subtotals. ### Section 7\. Subquery - [Subquery](./postgresql-tutorial/postgresql-subquery/ 'PostgreSQL Subquery') – write a query nested inside another query. - [Correlated Subquery](./postgresql-tutorial/postgresql-correlated-subquery/) – show you how to use a correlated subquery to perform a query that depends on the values of the current row being processed. - [ANY](./postgresql-tutorial/postgresql-any/)  – retrieve data by comparing a value with a set of values returned by a subquery. - [ALL](./postgresql-tutorial/postgresql-all/) – query data by comparing a value with a list of values returned by a subquery. - [EXISTS](./postgresql-tutorial/postgresql-exists/)  – check for the existence of rows returned by a subquery. ### Section 8\. Common Table Expressions - [PostgreSQL CTE](./postgresql-tutorial/postgresql-cte/) – introduce you to PostgreSQL common table expressions or CTEs. - [Recursive query using CTEs](./postgresql-tutorial/postgresql-recursive-query/) – discuss the recursive query and learn how to apply it in various contexts. ### Section 9\. Modifying Data In this section, you will learn how to insert data into a table with the `INSERT` statement, modify existing data with the `UPDATE` statement, and remove data with the `DELETE` statement. Additionally, you will learn how to use the UPSERT statement to merge data. - [Insert](./postgresql-tutorial/postgresql-insert/ 'PostgreSQL INSERT') – guide you on how to insert a single row into a table. - [Insert multiple rows](./postgresql-tutorial/postgresql-insert-multiple-rows/) – show you how to insert multiple rows into a table. - [Update](./postgresql-tutorial/postgresql-update/ 'PostgreSQL UPDATE') – update existing data in a table. - [Update join](./postgresql-tutorial/postgresql-update-join/) – update values in a table based on values in another table. - [Delete](./postgresql-tutorial/postgresql-delete/ 'PostgreSQL DELETE') – delete data in a table. - [Upsert](./postgresql-tutorial/postgresql-upsert/) – insert or update data if the new row already exists in the table. ### Section 10\. Transactions - [PostgreSQL Transactions](./postgresql-tutorial/postgresql-transaction/) – show you how to handle transactions in PostgreSQL using BEGIN, COMMIT, and ROLLBACK statements. ### Section 11\. Import \& Export Data You will learn how to import and export PostgreSQL data from and to CSV file format using the copy command. - [Import CSV file into Table](./postgresql-tutorial/import-csv-file-into-posgresql-table/) – show you how to import CSV file into a table. - [Export PostgreSQL Table to CSV file](./postgresql-tutorial/export-postgresql-table-to-csv-file/) – show you how to export tables to a CSV file. ### Section 12\. Managing Tables In this section, you will begin exploring the PostgreSQL data types and learn how to create new tables and modify the structure of the existing ones. - [Data types](./postgresql-tutorial/postgresql-data-types/ 'PostgreSQL Data Types') – cover the most commonly used PostgreSQL data types. - [Create a table](./postgresql-tutorial/postgresql-create-table/ 'PostgreSQL CREATE TABLE') – guide you on how to create a new table in the database. - [Select Into](./postgresql-tutorial/postgresql-select-into/) \& [Create table as](./postgresql-tutorial/postgresql-create-table-as/)– shows you how to create a new table from the result set of a query. - [Auto\-increment](./postgresql-tutorial/postgresql-serial/) column with SERIAL – uses SERIAL to add an auto\-increment column to a table. - [Sequences](./postgresql-tutorial/postgresql-sequences/) – introduce you to sequences and describe how to use a sequence to generate a sequence of numbers. - [Identity column](./postgresql-tutorial/postgresql-identity-column/) – show you how to use the identity column. - [Alter table](./postgresql-tutorial/postgresql-alter-table/ 'PostgreSQL ALTER TABLE') – modify the structure of an existing table. - [Rename table](./postgresql-tutorial/postgresql-rename-table/) – change the name of the table to a new one. - [Add column](./postgresql-tutorial/postgresql-add-column/) – show you how to add one or more columns to an existing table. - [Drop column](./postgresql-tutorial/postgresql-drop-column/) – demonstrate how to drop a column of a table. - [Change column data type](./postgresql-tutorial/postgresql-change-column-type/) – show you how to change a column’s data. - [Rename column](./postgresql-tutorial/postgresql-rename-column/) – illustrate how to rename one or more table columns. - [Drop table](./postgresql-tutorial/postgresql-drop-table/ 'PostgreSQL DROP TABLE') – remove an existing table and all of its dependent objects. - [Truncate table](./postgresql-tutorial/postgresql-truncate-table/ 'PostgreSQL TRUNCATE TABLE') – remove all data in a large table quickly and efficiently. - [Temporary table](./postgresql-tutorial/postgresql-temporary-table/) – show you how to use the temporary table. - [Copy a table](./postgresql-tutorial/postgresql-copy-table/) – show you how to copy a table to a new one. ### Section 13\. PostgreSQL Constraints - [Primary key](./postgresql-tutorial/postgresql-primary-key/) – illustrate how to define a primary key when creating a table or adding a primary key to an existing table. - [Foreign key](./postgresql-tutorial/postgresql-foreign-key/) – show you how to define foreign key constraints when creating a new table or adding foreign key constraints for existing tables. - [DELETE CASCADE](./postgresql-tutorial/postgresql-delete-cascade/) – show you how to automatically delete rows in child tables when the corresponding rows in the parent table are deleted. - [CHECK constraint](./postgresql-tutorial/postgresql-check-constraint/) – add logic to check value based on a Boolean expression. - [UNIQUE constraint](./postgresql-tutorial/postgresql-unique-constraint/) – ensure that values in a column or a group of columns are unique across the table. - [NOT NULL constraint](./postgresql-tutorial/postgresql-not-null-constraint/) – ensure values in a column are not NULL. - [DEFAULT constraint](./postgresql-tutorial/postgresql-default-value/) – specify a default value for a column using the DEFAULT constraint. ### Section 14\. PostgreSQL Data Types in Depth - [Boolean](./postgresql-tutorial/postgresql-boolean/) – store `TRUE` and `FALSE`values with the Boolean data type. - [CHAR, VARCHAR, and TEXT](./postgresql-tutorial/postgresql-char-varchar-text/) – learn how to use various character types including `CHAR`, `VARCHAR`, and `TEXT`. - [NUMERIC](./postgresql-tutorial/postgresql-numeric/) – show you how to use `NUMERIC` type to store values that precision is required. - [DOUBLE PRECISION](./postgresql-tutorial/postgresql-double-precision-type/) – learn to store inexact, variable\-precision numbers in the database. The DOUBLE PRECISION type is also known as the FLOAT type. - [REAL](./postgresql-tutorial/postgresql-real-data-type/) – guide you on how to use single\-precision floating\-point numbers in the database. - [Integer](./postgresql-tutorial/postgresql-integer/) – introduce you to various integer types in PostgreSQL including `SMALLINT`, `INT` and `BIGINT`. - [DATE](./postgresql-tutorial/postgresql-date/)  – introduce the `DATE` data type for storing date values. - [Timestamp](./postgresql-tutorial/postgresql-timestamp/) – understand timestamp data types quickly. - [Interval](./postgresql-tutorial/postgresql-interval/) – show you how to use interval data type to handle a period effectively. - [TIME](./postgresql-tutorial/postgresql-time/) – use the `TIME` datatype to manage the time of day values. - [UUID](./postgresql-tutorial/postgresql-uuid/) – guide you on how to use `UUID` datatype and how to generate `UUID` values using supplied modules. - [Array](./postgresql-tutorial/postgresql-array/) – show you how to work with arrays and introduce you to some handy functions for array manipulation. - [hstore](./postgresql-tutorial/postgresql-hstore/) – introduce you to the hstore data type, a set of key/value pairs stored in a single value in PostgreSQL. - [JSON](./postgresql-tutorial/postgresql-json/) – illustrate how to work with JSON data type and use some of the most important JSON operators and functions. - [User\-defined data types](./postgresql-tutorial/postgresql-user-defined-data-types/) – show you how to use the `CREATE DOMAIN` and `CREATE TYPE` statements to create user\-defined data types. - [Enum](./postgresql-tutorial/postgresql-enum/) – learn how to create an enum type that defines a list of fixed values for a column. - [XML](./postgresql-tutorial/postgresql-xml-data-type/) – show you how to store XML documents in the database using the XML data type. - [BYTEA](./postgresql-tutorial/postgresql-bytea-data-type/) – learn how to store binary strings in the database. - [Composite Types](./postgresql-tutorial/postgresql-composite-types/) – show you how to define a composite type that consists of multiple fields. ### Section 15\. Conditional Expressions \& Operators - [CASE](./postgresql-tutorial/postgresql-case/) – show you how to form conditional queries with `CASE` expression. - [COALESCE](./postgresql-tutorial/postgresql-coalesce/) – return the first non\-null argument. You can use it to substitute `NULL` by a default value. - [NULLIF](./postgresql-tutorial/postgresql-nullif/) – return `NULL` if the first argument equals the second one. - [CAST](./postgresql-tutorial/postgresql-cast/) – convert from one data type into another e.g., from a string into an integer, from a string into a date. ### Section 16\. PostgreSQL Utilities - [psql commands](./postgresql-administration/psql-commands/) – show you the most common psql commands that help you interact with psql faster and more effectively. ### Section 17\. PostgreSQL Recipes - [How to compare two tables](./postgresql-tutorial/compare-two-tables-in-postgresql/) – describe how to compare data in two tables in a database. - [How to delete duplicate rows in PostgreSQL](./postgresql-tutorial/how-to-delete-duplicate-rows-in-postgresql/) – show you various ways to delete duplicate rows from a table. - [How to generate a random number in a range](./postgresql-tutorial/postgresql-random-range/)  – illustrate how to generate a random number in a specific range. - [EXPLAIN statement](./postgresql-tutorial/postgresql-explain/)– guide you on how to use the `EXPLAIN` statement to return the execution plan of a query. - [PostgreSQL vs. MySQL](./postgresql-tutorial/postgresql-vs-mysql/) – compare PostgreSQL with MySQL in terms of functionalities. ## Advanced PostgreSQL Tutorial This advanced PostgreSQL tutorial covers the advanced concepts including stored procedures, indexes, views, triggers, and database administrations. ![](/postgresqltutorial/postgresql-plpgsql.svg?alignleft) ### [PostgreSQL PL/pgSQL](./postgresql-plpgsql/) This PostgreSQL stored procedures section shows you step by step how to develop PostgreSQL user\-defined functions using PL/pgSQL procedural language.![](/postgresqltutorial/postgresql-triggers.svg?alignleft) ### [PostgreSQL Triggers](./postgresql-triggers/) This section provides you with PostgreSQL trigger concept and shows how to manage triggers in PostgreSQL.![](/postgresqltutorial/postgresql-views.svg?alignleft) ### [PostgreSQL Views](./postgresql-views/) This section introduces you to PostgreSQL views concept and shows you how to manage views in the database.![](/postgresqltutorial/postgresql-indexes.svg?alignleft) ### [PostgreSQL Indexes](./postgresql-indexes/) In this tutorial, you will learn how to use PostgreSQL indexes to enhance the data retrieval speed and various index types.![](/postgresqltutorial/postgresql-administration.svg?alignleft) ### [PostgreSQL Administration](./postgresql-administration/) PostgreSQL administration covers common database administrative tasks including role and database management, backup, and restore.