Difference between revisions of "Inserting Data into a MySQL Database"
(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...) |
(→Inserting a Complete Row) |
||
Line 29: | Line 29: | ||
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. | 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. | + | 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. The other danger of this approach is that the statement may work based on the current table layout but will cause porblems should the layout be altered at a later date. With these warnings in mind, here is an example of specifying just the values: |
+ | |||
+ | 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: | ||
+ | |||
+ | <pre> | ||
+ | INSERT INTO products | ||
+ | VALUES( | ||
+ | NULL, | ||
+ | 'CD-RW Model 4543', | ||
+ | 'CD Writer', | ||
+ | 'Shelf 4B', | ||
+ | 10 | ||
+ | }; | ||
+ | </pre> | ||
+ | |||
+ | == Adding Multiple Rows to a Table == | ||
+ | |||
+ | Adding multiple rows to a table can be achieved either using multiple ''INSERT'' statements or by submitting all the rows as part of a single ''INSERT'' statement. |
Revision as of 13:46, 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. The other danger of this approach is that the statement may work based on the current table layout but will cause porblems should the layout be altered at a later date. With these warnings in mind, here is an example of specifying just the values:
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 VALUES( NULL, 'CD-RW Model 4543', 'CD Writer', 'Shelf 4B', 10 };
Adding Multiple Rows to a Table
Adding multiple rows to a table can be achieved either using multiple INSERT statements or by submitting all the rows as part of a single INSERT statement.