Difference between revisions of "Inserting Data into a MySQL Database"

From Techotopia
Jump to: navigation, search
(New page: A database would be of little use if it did not contain any data. It is, therefore, not surprising that the ''INSERT'' statement is one of the most commonly used statements. In this chapt...)
(No difference)

Revision as of 13:30, 3 October 2007

A database would be of little use if it did not contain any data. It is, therefore, not surprising that the INSERT statement is one of the most commonly used statements.

In this chapter of MySQL Essentials we will explain how to insert data into database tables using the SQL INSERT statement.

The Basics of Data Insertion

The purpose of the SQL INSERT statement is to add new rows of data to a specified database table. Using the INSERT statement, it is possible to insert a complete row, a partial rwo, multiple rows or rows generated as the result of a database query. In this chapter we will look at each of these techniques in turn.

Inserting a Complete Row

In order to add a single, complete row to a table the INSERT statement must be provided with the name of the table which the row is to be added, together with the column names and associated values to be added. The INSERT command first takes a comma separated list of column names enclosed in parentheses. This is followed by the VALUES keyword and then a comman separated list of values for each column. Note that the values must be listed in the same order as the column names. For example:

INSERT INTO products(
     product_id,
     product_name,
     product_description,
     product_location,
     product_quantity)
VALUES(
     NULL,
     'CD-RW Model 4543',
     'CD Writer',
     'Shelf 4B',
     10
};

Note that the product_id is specified as NULL. This is because the product_id in our imaginmary table is set to AUTO_INCREMENT so we do not specifically set this. Instead, the MySQL database engine will automatically create a new value for us.

A less safe way to add records to a table is to provide only the values. Whilst this approach works it is vital that the values be specified in the exact order in which the columns were specified when the table was created. Getting the wrong order will, at the very least result in a an error message (if the data types do not match the columns) and at the worst result in data going into the wrong columns.