Удаление таблицы в postgresql python

Use cases of the DB API for a PostgreSQL database

Python lets you write programs that access, display and update the information in the database with minimal effort.

There are lots of commercial and freeware databases available, and most of them provide Structured Query Language (SQL) for retrieving and adding information. However, while most databases have SQL in common, the details of how to perform an SQL operation vary. The various individuals who wrote the Python database modules invented their own interfaces, and the resulting proliferation of different Python modules caused problems: no two of them were exactly alike, so if you decided to switch to a new database product, you had to rewrite all the code that retrieved and inserted data.

To solve the problem, a Special Interest Group (or SIG) for databases was formed. After some discussion, the Database SIG produced a specification for a consistent interface to relational databases — the DB-API.

Python DB-API

Thanks to DB-API specification, there’s only one interface to learn. Porting code to use a different database product is much simpler, often requiring the change of only a few lines.

This API has been defined to encourage similarity between the Python modules that are used to access databases. By doing this, we hope to achieve a consistency leading to more easily understood modules, code that is generally more portable across databases, and a broader reach of database connectivity from Python.

Читайте также:  Save image as with javascript

Current version of DB-API is 2.0 (PEP 249) replaced older DB-API 1.0 version (PEP 248). Modules for most known relational databases now conform to DB-API 2.0 (or at least 1.0)

PostgreSQL

PostgreSQL is a powerful, open source relational database system. It has more than 15 years of active development and a proven architecture that has earned it a strong reputation for reliability, data integrity, and correctness. It runs on all major operating systems.

It includes most SQL92 and SQL99 data types. It also supports storage of binary large objects, including pictures, sounds, or video. It has native programming interfaces for C/C++, Java, .Net, Perl, Python, Ruby, Tcl, ODBC, among others.

Python interfaces to PostgreSQL

PyGreSQL

PyGreSQL is an open-source Python module that interfaces to a PostgreSQL database. It embeds the PostgreSQL query library to allow easy use of the powerful PostgreSQL features from a Python script.

PyGreSQL homepage

pyPgSQL

pyPgSQL is a package of two modules that provide a Python DB-API 2.0 compliant interface to PostgreSQL databases. The first module, libpq, exports the PostgreSQL C API to Python. This module is written in C and can be compiled into Python or can be dynamically loaded on demand. The second module, PgSQL, provides the DB-API 2.0 compliant interface.

pyPgSQL homepage

psycopg2

psycopg2 is a PostgreSQL database adapter for the Python programming language. Its main advantages are that it supports the full Python DBAPI 2.0 and it is thread safe at level 2. It was designed for heavily multi-threaded applications that create and destroy lots of cursors and make a conspicuous number of concurrent INSERTs or UPDATEs.

psycopg homepage

Basic examples

All examples tested on Python 2.4.4 and PostgreSQL 8.2 under Debian GNU/Linux 4.0, but should work on greater Python versions and other operational systems.

This part will take you on a fast tour of the main features of DB-API 2.0, showing howto:

  • open a connection to the database
  • create cursor
  • execute various query
  • close connection

All listed examples include SQL and DB-API version of actions.

Getting Started

For the first time we need to run python interpreter, import database module (e.g. psycopg2) and connect to database. Also we need to obtain a cursor object, which acts as a handle for a given SQL query; it allows retrieval of one or more rows of the result, until all the matching rows have been processed.

Python DB-API:

import psycopg2 as dbapi2 db = dbapi2.connect (database="python", user="python", password="python") cur = db.cursor()

Create database

Usually your system administrator must create databases for you, but if you use your own PostgreSQL server you can do it without assistance.

Create table

The created database is empty, so it doesn’t contain any user tables or data. We must create a new table and specify its columns.

CREATE TABLE versions (released date, version varchar, status varchar);
cur.execute ("""CREATE TABLE versions (released date, version varchar, status varchar)""")

Add data

To insert data into the table we can use the execute method of the cursor object. Use the commit() method to commit, i.e. make permanent, the changes to the database.

INSERT INTO versions VALUES ('2007-10-18', '2.4.4', 'stable'); INSERT INTO versions VALUES ('2007-04-18', '2.5.1', 'stable'); INSERT INTO versions (version, status) VALUES ('2.6.0', 'devel') INSERT INTO versions (verson, status) VALUES ('3.0.0', 'alpha')
cur.execute ("INSERT INTO versions VALUES ('2007-10-18', '2.4.4', 'stable')") cur.execute ("INSERT INTO versions VALUES ('2007-04-18', '2.5.1', 'stable')") cur.execute ("INSERT INTO versions (version, status) VALUES ('2.6.0', 'devel')") cur.execute ("INSERT INTO versions (version, status) VALUES ('3.0.0', 'alpha')") conn.commit ()

Retrieve data

Use the execute function to run sql SELECT queries.

cur.execute ("SELECT * FROM versions"); rows = cur.fetchall() for i, row in enumerate(rows): print "Row", i, "value = ", row Row 0 value = (datetime.date(2007, 10, 18), '2.4.4', 'stable') Row 1 value = (datetime.date(2007, 4, 18), '2.5.1', 'stable') Row 2 value = (None, '2.6.0', 'devel') Row 3 value = (None, '3.0.0', 'alpha')

Delete data

Use the execute function to run sql DELETE or DROP TABLE. You don’t need to delete all the rows from the table before dropping it.

DELETE FROM versions; DROP TABLE versions;
cur.execute ("DELETE FROM versions") cur.execute ("DROP TABLE versions")

Close Connection

When you finish work with a cursor or database, closing the cursor and connection is good practice (but isn’t necessary).

Advanced examples

Advanced querying

You can use all the normal SQL operators like WHERE, GROUP BY, ORDER BY, etc in queries which execute through the execute() method of a cursor object. But be careful when you use database dependent operators, because your code will depends on used database.

SELECT * FROM versions WHERE status = 'stable' ORDER BY version DESC;
cur.execute ("""SELECT * FROM versions WHERE status = 'stable' ORDER BY version DESC;""") rows = cur.fetchall() for i, row in enumerate(rows): print "Row", i, "value = ", row Row 0 value = (datetime.date(2007, 4, 18), '2.5.1', 'stable') Row 1 value = (datetime.date(2007, 10, 18), '2.4.4', 'stable')

Transactions

For databases that support transactions, the Python interface silently starts a transaction when the cursor is created. The commit() method commits the updates made using that cursor, and the rollback() method discards them. Each method then starts a new transaction. Some databases don’t have transactions, but simply apply all changes as they’re executed. On these databases:

  • commit() does nothing, but you should still call it in order to be compatible with those databases that do support transactions.
  • rollback() should throw an exception or not be implemented.
BEGIN TRANSACTION; UPDATE versions SET status='stable' where version='2.6.0'; UPDATE versions SET status='old' where version='2.4.4'; SELECT * FROM versions; released | version | status ------------+---------+-------- 2007-04-18 | 2.5.1 | stable | 3.0.0 | alpha | 2.6.0 | stable 2007-10-18 | 2.4.4 | old ROLLBACK SELECT * FROM versions; released | version | status ------------+---------+-------- 2007-10-18 | 2.4.4 | stable 2007-04-18 | 2.5.1 | stable | 2.6.0 | devel | 3.0.0 | alpha
try: cur.execute ("""UPDATE versions SET status='stable' where version='2.6.0' """) cur.execute ("""UPDATE versions SET status='old' where version='2.4.4' """) db.commit() except Exception, e: db.rollback()

References

  1. The Python DB-API interface http://www.amk.ca/python/writing/DB-API.html by Andrew Kuchling
  2. Python Database API Specification v2.0 http://www.python.org/dev/peps/pep-0249/
  3. Accessing Databases using the Python DBAPI-2.0 http://www.initd.org/pub/software/psycopg/dbapi20programming.pdf

UsingDbApiWithPostgres (last edited 2010-02-15 14:47:49 by 94-194-202-224 )

Источник

Python PostgreSQL — Drop Table

You can drop a table from PostgreSQL database using the DROP TABLE statement.

Syntax

Following is the syntax of the DROP TABLE statement in PostgreSQL −

Example

Assume we have created two tables with name CRICKETERS and EMPLOYEES using the following queries −

postgres=# CREATE TABLE CRICKETERS ( First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, Place_Of_Birth VARCHAR(255), Country VARCHAR(255) ); CREATE TABLE postgres=# postgres=# CREATE TABLE EMPLOYEE( FIRST_NAME CHAR(20) NOT NULL, LAST_NAME CHAR(20), AGE INT, SEX CHAR(1), INCOME FLOAT ); CREATE TABLE postgres=#

Now if you verify the list of tables using the “\dt” command, you can see the above created tables as −

postgres=# \dt; List of relations Schema | Name | Type | Owner --------+------------+-------+---------- public | cricketers | table | postgres public | employee | table | postgres (2 rows) postgres=#

Following statement deletes the table named Employee from the database −

postgres=# DROP table employee; DROP TABLE

Since you have deleted the Employee table, if you retrieve the list of tables again, you can observe only one table in it.

postgres=# \dt; List of relations Schema | Name | Type | Owner --------+------------+-------+---------- public | cricketers | table | postgres (1 row) postgres=#

If you try to delete the Employee table again, since you have already deleted it, you will get an error saying “table does not exist” as shown below −

postgres=# DROP table employee; ERROR: table "employee" does not exist postgres=#

To resolve this, you can use the IF EXISTS clause along with the DELTE statement. This removes the table if it exists else skips the DLETE operation.

postgres=# DROP table IF EXISTS employee; NOTICE: table "employee" does not exist, skipping DROP TABLE postgres=#

Removing an entire table using Python

You can drop a table whenever you need to, using the DROP statement. But you need to be very careful while deleting any existing table because the data lost will not be recovered after deleting a table.

import psycopg2 #establishing the connection conn = psycopg2.connect( database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432' ) #Setting auto commit false conn.autocommit = True #Creating a cursor object using the cursor() method cursor = conn.cursor() #Doping EMPLOYEE table if already exists cursor.execute("DROP TABLE emp") print("Table dropped. ") #Commit your changes in the database conn.commit() #Closing the connection conn.close()

Источник

Оцените статью