The SQL DELETE command is used to delete rows that are no longer required from the database tables. It deletes the whole row from the table. Delete command comes in handy to delete temporary or obsolete data from your database.The DELETE command can delete more than one row from a table in a single query. This proves to be advantages when removing large numbers of rows from a database table.
Once a row has been deleted, it cannot be recovered. It is therefore strongly recommended to make database backups before deleting any data from the database. This can allow you to restore the database and view the data later on should it be required.
The basic syntax of the delete command is as shown below.
If the WHERE clause is not used in the DELETE query, then all the rows in a given table will be deleted. Before we go into more details discussion the DELETE command, let"s insert some sample data into the movies table to work with.
INSERT INTO `movies` (`title`, `director`, `year_released`, `category_id`) VALUES ("The Great Dictator", "Chalie Chaplie", 1920, 7); INSERT INTO `movies` (`title`, `director`, `category_id`) VALUES ("sample movie", "Anonymous", 8); INSERT INTO movies (`title`, `director`, `year_released`, `category_id`) VALUES ("movie 3", "John Brown", 1920, 8);
Executing the above script adds three (3) movies into the movies table. Before we go any further into our lesson, let"s get all the movies in our table. The script shown below does that.
SELECT * FROM `movies`;
movie_id | itle | director | year_released | category_id |
---|---|---|---|---|
1 | Pirates of the Caribean 4 | Rob Marshall | 2011 | 1 |
2 | Forgetting Sarah Marshal | Nicholas Stoller | 2008 | 2 |
3 | X-Men | NULL | 2008 | NULL |
4 | Code Name Black | Edgar Jimz | 2010 | NULL |
5 | Daddy"s Little Girls | NULL | 2007 | 8 |
6 | Angels and Demons | NULL | 2007 | 6 |
7 | Davinci Code | NULL | 2007 | 6 |
9 | Honey mooners | John Schultz | 2005 | 8 |
16 | 67% Guilty | NULL | 2012 | NULL |
18 | The Great Dictator | Chalie Chaplie | 1920 | 7 |
19 | sample movie | Anonymous | NULL | 8 |
20 | movie 3 | John Brown | 1920 | 8 |
Let"s suppose that the Myflix video library no longer wishes to be renting out "The Great Dictator" to its members and they want it removed from the database. Its movie id is 18, we can use the script shown below to delete its row from the movies table.
Executing the above script in MySQL WorkBench against the Myflix deletes the movie with id 18 from the database table.
Let"s see the current status of movies table.
SELECT * FROM `movies`;
movie_id | title | director | year_released | category_id |
---|---|---|---|---|
1 | Pirates of the Caribean 4 | Rob Marshall | 2011 | 1 |
2 | Forgetting Sarah Marshal | Nicholas Stoller | 2008 | 2 |
3 | X-Men | NULL | 2008 | NULL |
4 | Code Name Black | Edgar Jimz | 2010 | NULL |
5 | Daddy"s Little Girls | NULL | 2007 | 8 |
6 | Angels and Demons | NULL | 2007 | 6 |
7 | Davinci Code | NULL | 2007 | 6 |
9 | Honey mooners | John Schultz | 2005 | 8 |
16 | 67% Guilty | NULL | 2012 | NULL |
19 | sample movie | Anonymous | NULL | 8 |
20 | movie 3 | John Brown | 1920 | 8 |
Let"s say we have a list of movies we want to delete . We can use the WHERE clause along with IN.
Executing the above script deletes movies with IDs 20 and 21 from our movies table.
The Update command is used to modify rows in a table. The update command can be used to update a single field or multiple fields at the same time. It can also be used to update a table with values from another table .
The basic syntax of the SQL Update command is as shown below.
Let"s now look at a practical example that updates data in the members table. Let"s suppose that our member"s membership numbers 1 and 2 have the following updates to be made to their data records.
Membership number | Updates required |
1 | Changed contact number from 999 to 0759 253 532 |
2 | Change the name to Janet Smith Jones and physical address should be updated to Melrose 123 |
We will start with making updates for membership number 1 before we make any updates to our data, let"s retrieve the record for membership number 1. The script shown below helps us to do that.
Executing the above script gives us the following results.
membership_number | full_names | gender | date_of_birth | physical_address | postal_address | contct_number | |
---|---|---|---|---|---|---|---|
1 | Janet Jones | Female | 21-07-1980 | First Street Plot No 4 | Private Bag | 999 |
Let"s now update the contact number using the script shown below.
Executing the above script updates the contact number from 999 to 0759 253 532 for membership number 1. Let"s now look at the record for membership number 1 after executing the update script.
Executing the above script gives us the following results.
membership_number | full_names | gender | date_of_birth | physical_address | postal_address | contct_number | |
---|---|---|---|---|---|---|---|
1 | Janet Jones | Female | 21-07-1980 | First Street Plot No 4 | Private Bag | 0759 253 542 | This email address is being protected from spambots. You need JavaScript enabled to view it. |
Let"s now look at the updates required for membership number 2.
membership_number | full_names | gender | date_of_birth | physical_address | postal_address | contct_number | |
---|---|---|---|---|---|---|---|
2 | Smith Jones | Female | 23-06-1980 | Park Street | NULL | NULL | This email address is being protected from spambots. You need JavaScript enabled to view it. |
The following script helps us to do that.
Executing the above script in updates the full names for membership number 2 to Janet Smith Jones and the physical address to Melrose 123.
membership_number | full_names | gender | date_of_birth | physical_address | postal_address | contct_number | |
---|---|---|---|---|---|---|---|
2 | Janet Smith Jones | Female | 23-06-1980 | Melrose 123 | NULL | NULL | This email address is being protected from spambots. You need JavaScript enabled to view it. |
Если нам нужно изменить или обновить данные в MySQL, мы можем использовать SQL команду UPDATE для работы. ,
Ниже приводится команда UPDATE для изменения данных MySQL Sheet Data Общие SQL синтаксис:
UPDATE table_name SET field1=new-value1, field2=new-value2
Когда вам нужно обновить данные, указанные в строках таблицы ИНЕКЕ очень полезно.
Командной строки, чтобы обновить данные
Ниже мы будем обновлять w3big_tbl указанные в таблице данных с помощью команды SQL UPDATE ИНЕКЕ:
В следующем примере будет обновлять таблицу данных в качестве w3big_title w3big_id значения поля 3:
# mysql -u root -p password; Enter password:******* mysql> use w3big; Database changed mysql> UPDATE w3big_tbl -> SET w3big_title="Learning JAVA" -> WHERE w3big_id=3; Query OK, 1 row affected (0.04 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql>PHP функция для использования mysql_query () для выполнения операторов SQL, вы можете использовать оператор UPDATE SQL или ИНЕКЕ не применяется.
Эта функция в MySQL> командной строки эффект выполнения операторов SQL то же самое.
В следующем примере будет обновлять данные w3big_id поле w3big_title 3.
В этом учебном пособии вы узнаете, как использовать MySQL оператор UPDATE
с синтаксисом и примерами.
MySQL оператор UPDATE используется для обновления существующих записей в таблице в базе данных MySQL. Существует три синтаксиса для оператора UPDATE в зависимости от типа обновления, которое вы хотите выполнить.
Простая форма синтаксиса для оператора UPDATE при обновлении одной таблицы в MySQL:
Теперь полный синтаксис для MySQL оператора UPDATE при обновлении одной таблицы:
ИЛИ
Синтаксис оператора UPDATE при обновлении одной таблицы данными из другой таблицы в MySQL:
ИЛИ
Синтаксис MySQL оператора UPDATE при обновлении нескольких таблиц:
LOW_PRIORITY
— необязательный. Если указан LOW_PRIORITY
, обновление будет отложено до тех пор, пока не будет процессов читающих из таблицы. LOW_PRIORITY
может использоваться с таблицами MyISAM, MEMORY и MERGE, которые используют блокировку на уровне таблицы.
IGNORE
— необязательный. Если предоставляется IGNORE
, все ошибки, возникающие во время обновления, игнорируются. Если обновление в строке приведет к нарушению первичного ключа или уникального индекса, обновление в этой строке не будет выполнено.
column1
, column2
— столбцы, которые вы хотите обновить.
expression1
, expression2
— новые значения для назначения column1
, column2
. Таким образом, column1
присваивается значение expression1
, column2
присваивается значение expression2
и т. д.
WHERE conditions
— необязательный. Условия, которые должны выполняться для выполнения обновления.
ORDER BY expression
— необязательный. Он может использоваться в сочетании с LIMIT
для сортировки записей соответствующим образом при ограничении количества записей, подлежащих обновлению.
LIMIT number_rows
— необязательный. Если указан LIMIT
, он контролирует максимальное количество записей для обновления в таблице. Максимальное количество записей, указанных в файле number_rows
, будет обновляться в таблице.
Рассмотрим очень простой пример MySQL запроса UPDATE.
В этом MySQL примере UPDATE обновил поле last_name на ‘Ford’ в таблице customers , где customer_id = 500.
Рассмотрим пример MySQL UPDATE, где вы можете обновить более одного столбца с помощью одного оператора UPDATE.
Если вы хотите обновить несколько столбцов, вы можете сделать это, разделив пары столбца / значения запятыми.
Этот пример инструкции MySQL UPDATE обновил state
в ‘Nevada’ и customer_rep
до 23, где customer_id
больше 200.
Рассмотрим пример UPDATE, который показывает, как обновить таблицу данными из другой таблицы в MySQL.
MySQL
В этом примере UPDATE будет обновляться только таблица customers для всех записей, где customer_id больше 5000. Когда supplier_name из таблицы suppliers совпадает с именем customer_name из таблицы customers , city из таблицы suppliers будет скопирован в поле city таблицы customers .
Однотабличный синтаксис:
UPDATE шя_таблтш
SET имя_столбца1=выражение1 [,
имя_столбца2=выражение2 ...]
Многотабличный синтаксис:
UPDATE имя_таблицы [, имя_таблицы...] SET имя_столбца 1=выражение1 [,имя_столбца2=выражение2
...]
Оператор UPDATE обновляет столбцы существующих строк таблицы новыми значе-ниями. Конструкция SET перечисляет столбцы, подлежащие модификации, и значения, которые им присваиваются. Если указана конструкция WHERE, она задает, какие строки должны быть обновлены. В противном случае обновляются все строки таблицы. Если указана конструкция ORDER BY, строки будут обновлены в заданном порядке. Конструк-ция LIMIT накладывает ограничение на количество обновляемых строк.
Оператор UPDATE поддерживает следующие модификаторы:
Если вы используете столбцы из таблицы имя_таблицы
в выражениях, UPDATE исполь-зует текущее значение столбцов. Например, следующий оператор увеличивает значение столбца age на единицу:
mysql> UPDATE persondata SET age=age+l;
Присвоения в UPDATE выполняются слева направо. Например, следующий оператор удваивает значение столбца age, а затем увеличивает на единицу: mysql> UPDATE persondata SET age=age*2, age=age+l;
Если вы устанавливает значение столбца в то, которое он имеет, MySQL обнаружи-вает это и не выполняет обновление.
Если вы обновляете столбец, который была объявлен как NOT null, присваивая ему значение NULL, он устанавливается в значение по умолчанию, соответствующее конкрет-ному типу данных и увеличивает счетчик предупреждений на единицу. Значение по умолчанию равно 0 для числовых столбцов, пустая строка ("") для символьных и "нуле-вое" значение для столбцов типа даты и времени.
UPDATE возвращает количество строк, которые фактически были обновлены. В MySQL 3.22 и более поздних версиях функция mysql_info() программного интерфейса С API
возвращает количество строк, которые соответствовали запросу и были обновле-ны, а также количество предупреждений, возникших во время выполнения UPDATE.
Начиная с MySQL 3.23, можно использовать limit количество_строк
для ограниче-ния области действия UPDATE.
Конструкция LIMIT работает следующим образом:
Если оператор UPDATE включает конструкцию order by, то строки обновляются в по-рядке, заданном этой конструкцией. ORDER BY может применяться, начиная с MySQL 4.0.0.
Начиная с MySQL 4.0.0, также можно выполнять операции UPDATE, которые работают с несколькими таблицами сразу:
UPDATE items,month SET items.price=month.price WHERE items.id-month. id/ Этот пример демонстрирует внутреннее объединение, использующее оператор запя-той, но многотабличные UPDATE могут использовать любой тип объединений, допусти-мый в операторе SELECT, например, LEFT JOIN.
На заметку!
Оператор UPDATE обновляет столбцы в соответствии с их новыми значениями в строках существующей таблицы. В выражении SET указывается, какие именно столбцы следует модифицировать и какие величины должны быть в них установлены. В выражении WHERE , если оно присутствует, задается, какие строки подлежат обновлению. В остальных случаях обновляются все строки. Если задано выражение ORDER BY , то строки будут обновляться в указанном в нем порядке.
Если указывается ключевое слово LOW_PRIORITY , то выполнение данной команды UPDATE задерживается до тех пор, пока другие клиенты не завершат чтение этой таблицы.
Если указывается ключевое слово IGNORE , то команда обновления не будет прервана, даже если при обновлении возникнет ошибка дублирования ключей. Строки, из-за которых возникают конфликтные ситуации, обновлены не будут.
Если доступ к столбцу из указанного выражения осуществляется по аргументу tbl_name , то команда UPDATE использует для этого столбца его текущее значение. Например, следующая команда устанавливает столбец age в значение, на единицу большее его текущей величины:
Mysql> UPDATE persondata SET age=age+1;
Значения команда UPDATE присваивает слева направо. Например, следующая команда дублирует столбец age , затем инкрементирует его:
Mysql> UPDATE persondata SET age=age*2, age=age+1;
Если столбец устанавливается в его текущее значение, то MySQL замечает это и не обновляет его.
Команда UPDATE возвращает количество фактически измененных строк. В версии MySQL 3.22 и более поздних функция C API mysql_info() возвращает количество строк, которые были найдены и обновлены, и количество предупреждений, имевших место при выполнении UPDATE .
В версии MySQL 3.23 можно использовать LIMIT # , чтобы убедиться, что было изменено только заданное количество строк.