首页 > 数据库 > MySQL > 正文

MySQL数据插入 查询 删除语句详解

2024-07-24 12:37:24
字体:
来源:转载
供稿:网友

在mysql中数据保存,查询,删除都很简单,如插入数据使用insert into,查询数据使用select,删除数据使用delete这里我给大家介绍一下.

MySQL数据插入

将数据插入到MySQL表,需要使用SQL INSERT INTO命令,可以将数据插入到MySQL表使用mysql>提示符下或使用任何脚本,如PHP。

语法:下面是通用的SQL语法INSERT INTO命令来插入数据到MySQL表,代码如下:

  1. INSERT INTO table_name (field1, field2,...fieldN) VALUES (value1, value2,...valueN );

要插入的字符串数据类型,所有的值需要双或单引号,例如: - “value”,从命令提示符中插入数据,这将使用SQL INSERT INTO命令将数据插入到MySQL表tutorials_tbl.

实例,下面的例子将创建3条记录到tutorials_tbl表,代码如下:

  1. root@host# mysql -u root -p password
  2. Enter password:******* 
  3. mysql> use TUTORIALS; 
  4. Database changed 
  5. mysql> INSERT INTO tutorials_tbl  
  6.      ->(tutorial_title, tutorial_author, submission_date) 
  7.      ->VALUES 
  8.      ->("Learn PHP""John Poul", NOW()); 
  9. Query OK, 1 row affected (0.01 sec) 
  10. mysql> INSERT INTO tutorials_tbl 
  11.      ->(tutorial_title, tutorial_author, submission_date) 
  12.      ->VALUES --Vevb.com 
  13.      ->("Learn MySQL""Abdul S", NOW()); 
  14. Query OK, 1 row affected (0.01 sec) 
  15. mysql> INSERT INTO tutorials_tbl 
  16.      ->(tutorial_title, tutorial_author, submission_date) 
  17.      ->VALUES 
  18.      ->("JAVA Tutorial""Sanjay"'2007-05-06'); 
  19. Query OK, 1 row affected (0.01 sec) 
  20. mysql> 

注意:所有的箭头符号( - >)是不属于他们表示一个新行的SQL命令,他们会自动创建MySQL提示符下,同时按回车键没有在每一行命令结束的分号.

在上面的例子中,我们没有提供tutorial_id因为创建表时,为此字段定义一个AUTO_INCREMENT选项。因此MySQL负责自动插入这些ID。这里NOW()是一个MySQL函数返回当前的日期和时间。

使用PHP语言插入数据:可以使用相同SQL INSERT INTO命令PHP函数mysql_query()来将数据插入到MySQL表.

例子,这个例子将用户从三个参数,并把它们插入到MySQL表,代码如下:

  1. <html> 
  2. <head> 
  3. <title>Add New Record in MySQL Database -by /mysql</title> 
  4. </head> 
  5. <body> 
  6. <?php 
  7. if(isset($_POST['add'])) 
  8. $dbhost = 'localhost:3036'
  9. $dbuser = 'root'
  10. $dbpass = 'rootpassword'
  11. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  12. if(! $conn ) 
  13.   die('Could not connect: ' . mysql_error()); 
  14.  
  15. if(! get_magic_quotes_gpc() ) 
  16.    $tutorial_title = addslashes ($_POST['tutorial_title']); 
  17.    $tutorial_author = addslashes ($_POST['tutorial_author']); 
  18. else 
  19.    $tutorial_title = $_POST['tutorial_title']; 
  20.    $tutorial_author = $_POST['tutorial_author']; 
  21. $submission_date = $_POST['submission_date']; 
  22.  
  23. $sql = "INSERT INTO tutorials_tbl "
  24.        "(tutorial_title,tutorial_author, submission_date) "
  25.        "VALUES "
  26.        "('$tutorial_title','$tutorial_author','$submission_date')"
  27. mysql_select_db('TUTORIALS'); 
  28. $retval = mysql_query( $sql$conn ); 
  29. if(! $retval ) 
  30.   die('Could not enter data: ' . mysql_error()); 
  31. echo "Entered data successfullyn"
  32. mysql_close($conn); 
  33. else 
  34. ?> 
  35. <form method="post" action="<?php $_PHP_SELF ?>"
  36. <table width="600" border="0" cellspacing="1" cellpadding="2"
  37. <tr> 
  38. <td width="250">Tutorial Title</td> 
  39. <td> 
  40. <input name="tutorial_title" type="text" id="tutorial_title"
  41. </td> 
  42. </tr> 
  43. <tr> 
  44. <td width="250">Tutorial Author</td> 
  45. <td> 
  46. <input name="tutorial_author" type="text" id="tutorial_author"
  47. </td> 
  48. </tr> 
  49. <tr> 
  50. <td width="250">Submission Date [ yyyy-mm-dd ]</td> 
  51. <td> 
  52. <input name="submission_date" type="text" id="submission_date"
  53. </td> 
  54. </tr> 
  55. <tr> 
  56. <td width="250"> </td> 
  57. <td> </td> 
  58. </tr> 
  59. <tr> 
  60. <td width="250"> </td> 
  61. <td> 
  62. <input name="add" type="submit" id="add" value="Add Tutorial"
  63. </td> 
  64. </tr> 
  65. </table> 
  66. </form> 
  67. <?php 
  68. ?> 
  69. </body> 
  70. </html> 

数据插入其最好的做法是使用函数get_magic_quotes_gpc()来检查当前的配置设置或对魔术函数的引用。如果函数返回false,则使用函数addslashes()添加斜线引号之前。

MySQL数据查询:SQL SELECT命令被用来获取数据从MySQL数据库,可以使用此命令在mysql>提示符下或使用脚本,如PHP.

语法,下面是通用的SQL SELECT命令的语法来从MySQL表提取数据,代码如下:

  1. SELECT field1, field2,...fieldN table_name1, table_name2... 
  2. [WHERE Clause] 
  3. [OFFSET M ][LIMIT N] 

可以使用一个或多个以逗号分隔的表,包括各种使用WHERE子句条件,但是WHERE子句的SELECT命令是一个可选部分.

可以在一个单一的SELECT命令读取一个或多个字段,可以指定星号(*)的字段的地方,在这种情况下,SELECT将返回所有的字段,可以使用WHERE子句指定任何条件,可以指定偏移用SELECT将开始返回记录的偏移量,默认情况下,偏移量为0,可以限制返回的使用LIMIT属性的数量.

从命令提示符获取数据:这将使用SQL SELECT命令来从MySQL表tutorials_tbl获取数据.

例子,下面的例子将返回所有记录tutorials_tbl表,代码如下:

  1. root@host# mysql -u root -p password
  2. Enter password:******* 
  3. mysql> use TUTORIALS; 
  4. Database changed 
  5. mysql> SELECT * from tutorials_tbl  
  6. +-------------+----------------+-----------------+-----------------+ 
  7. | tutorial_id | tutorial_title | tutorial_author | submission_date | 
  8. +-------------+----------------+-----------------+-----------------+ 
  9. |           1 | Learn PHP      | John Poul       | 2007-05-21      | 
  10. |           2 | Learn MySQL    | Abdul S         | 2007-05-21      | 
  11. |           3 | JAVA Tutorial  | Sanjay          | 2007-05-21      | 
  12. +-------------+----------------+-----------------+-----------------+ 
  13. rows in set (0.01 sec) 
  14.  
  15. mysql> 

使用PHP脚本获取数据:您可以使用相同的SQL SELECT命令进入PHP函数mysql_query()。这个函数是用来执行SQL命令后,另一个PHP函数mysql_fetch_array()可以用来获取所有选定的数据,这个函数返回的行作为一个关联数组/数字数组或两者,如果没有更多的行这个函数返回FALSE。

下面是一个简单的例子,获取记录tutorials_tbl表.

例子,试试下面的例子显示tutorials_tbl表的所有记录,代码如下:

  1. <?php 
  2. $dbhost = 'localhost:3036'
  3. $dbuser = 'root'
  4. $dbpass = 'rootpassword'
  5. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  6. if(! $conn ) 
  7.   die('Could not connect: ' . mysql_error()); 
  8. $sql = 'SELECT tutorial_id, tutorial_title,  
  9.                tutorial_author, submission_date 
  10.         FROM tutorials_tbl'; 
  11.  
  12. mysql_select_db('TUTORIALS'); 
  13. $retval = mysql_query( $sql$conn ); 
  14. if(! $retval ) 
  15.   die('Could not get data: ' . mysql_error()); 
  16. while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) 
  17.     echo "Tutorial ID :{$row['tutorial_id']}  <br> "
  18.          "Title: {$row['tutorial_title']} <br> "
  19.          "Author: {$row['tutorial_author']} <br> "
  20.          "Submission Date : {$row['submission_date']} <br> "
  21.          "--------------------------------<br>"
  22. }  
  23. echo "Fetched data successfullyn"
  24. mysql_close($conn); 
  25. ?> 

这些行的内容被分配到变量$row,行中的值,然后打印.

注:一定要记住,当要插入到一个字符串数组的值直接用花括号.

在上面的例子中不断MYSQL_ASSOC作为PHP函数mysql_fetch_array()第二个参数,以便它返回一个关联数组的行为,一个关联数组,可以使用他们的名字,而不是使用索引访问字段.

PHP提供了另一种称为mysql_fetch_assoc()函数也返回该行作为关联数组。

实例,试试下面的例子显示从tutorial_tbl表的所有记录,使用mysql_fetch_assoc()函数,代码如下:

  1. <?php 
  2. $dbhost = 'localhost:3036'
  3. $dbuser = 'root'
  4. $dbpass = 'rootpassword'
  5. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  6. if(! $conn ) 
  7.   die('Could not connect: ' . mysql_error()); 
  8. $sql = 'SELECT tutorial_id, tutorial_title,  
  9.                tutorial_author, submission_date 
  10.         FROM tutorials_tbl'; 
  11.  
  12. mysql_select_db('TUTORIALS'); 
  13. $retval = mysql_query( $sql$conn ); 
  14. if(! $retval ) 
  15.   die('Could not get data: ' . mysql_error()); 
  16. while($row = mysql_fetch_assoc($retval)) 
  17.     echo "Tutorial ID :{$row['tutorial_id']}  <br> "
  18.          "Title: {$row['tutorial_title']} <br> "
  19.          "Author: {$row['tutorial_author']} <br> "
  20.          "Submission Date : {$row['submission_date']} <br> "
  21.          "--------------------------------<br>"
  22. }  
  23. echo "Fetched data successfullyn"
  24. mysql_close($conn); 
  25. ?> 

也可以使用常量MYSQL_NUM,作为第二个参数的PHP函数mysql_fetch_array(),这将导致该函数返回一个数字索引的数组.

实例,试试下面的例子显示使用MYSQL_NUM参数tutorials_tbl表中的所有记录,代码如下:

  1. <?php 
  2. $dbhost = 'localhost:3036'
  3. $dbuser = 'root'
  4. $dbpass = 'rootpassword'
  5. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  6. if(! $conn ) 
  7.   die('Could not connect: ' . mysql_error()); 
  8. $sql = 'SELECT tutorial_id, tutorial_title,  
  9.                tutorial_author, submission_date 
  10.         FROM tutorials_tbl'; 
  11.  
  12. mysql_select_db('TUTORIALS'); 
  13. $retval = mysql_query( $sql$conn ); 
  14. if(! $retval ) 
  15.   die('Could not get data: ' . mysql_error()); 
  16. while($row = mysql_fetch_array($retval, MYSQL_NUM)) 
  17.     echo "Tutorial ID :{$row[0]}  <br> "
  18.          "Title: {$row[1]} <br> "
  19.          "Author: {$row[2]} <br> "
  20.          "Submission Date : {$row[3]} <br> "
  21.          "--------------------------------<br>"
  22. echo "Fetched data successfullyn"
  23. mysql_close($conn); 
  24. ?> 

所有上述三个例子,将产生相同的结果.

释放内存:它是一种很好的做法,在每一个SELECT语句释放游标内存,这可以通过使用PHP函数了mysql_free_result(),下面的例子来说明它是如何被使用的.

实例,试试下面的例子,代码如下:

  1. <?php 
  2. $dbhost = 'localhost:3036'
  3. $dbuser = 'root'
  4. $dbpass = 'rootpassword'
  5. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  6. if(! $conn ) 
  7.   die('Could not connect: ' . mysql_error()); 
  8. $sql = 'SELECT tutorial_id, tutorial_title,  
  9.                tutorial_author, submission_date 
  10.         FROM tutorials_tbl'; 
  11.  
  12. mysql_select_db('TUTORIALS'); 
  13. $retval = mysql_query( $sql$conn ); 
  14. if(! $retval ) 
  15.   die('Could not get data: ' . mysql_error()); 
  16. while($row = mysql_fetch_array($retval, MYSQL_NUM)) 
  17.     echo "Tutorial ID :{$row[0]}  <br> "
  18.          "Title: {$row[1]} <br> "
  19.          "Author: {$row[2]} <br> "
  20.          "Submission Date : {$row[3]} <br> "
  21.          "--------------------------------<br>"
  22. mysql_free_result($retval); 
  23. echo "Fetched data successfullyn"
  24. mysql_close($conn); 
  25. ?> 

在获取数据的同时可以编写复杂的SQL,只要喜欢。程序将保持与上述相同

MySQL数据删除:如果想从任何MySQL表中删除一条记录,那么可以使用SQL命令DELETE FROM。可以使用此命令在mysql>提示符下,或其它脚本,如PHP。

语法,下面是通用的SQL语法的DELETE命令删除数据从一个MySQL表,代码如下:

DELETE FROM table_name [WHERE Clause]

如果没有指定,那么WHERE子句从给定的MySQL表的所有记录都将被删除,可以使用WHERE子句指定条件,您可以将表中记录一次性删除,当你要删除选定的表中的行,WHERE子句是非常有用。

从命令提示符删除数据:这将使用WHERE子句SQL DELETE命令来删除选定的数据MySQL表tutorials_tbl.

例子,下面的例子将删除一条tutorial_tbl表中的tutorial_id为3的记录,代码如下:

  1. root@host# mysql -u root -p password
  2. Enter password:******* 
  3. mysql> use TUTORIALS; 
  4. Database changed 
  5. mysql> DELETE FROM tutorials_tbl WHERE tutorial_id=3; 
  6. Query OK, 1 row affected (0.23 sec) 
  7.  
  8. mysql> 

使用PHP脚本删除数据:可以使用SQL DELETE命令,带有或不带WHERE子句PHP函数请求mysql_query(),此功能将执行和在mysql>提示符下执行的SQL命令类似。

例子,试试下面的例子中,将删除tutorial_tb表中一条tutorial_id=3的记录,代码如下:

  1. <?php 
  2. $dbhost = 'localhost:3036'
  3. $dbuser = 'root'
  4. $dbpass = 'rootpassword'
  5. $conn = mysql_connect($dbhost$dbuser$dbpass); 
  6. if(! $conn ) 
  7.   die('Could not connect: ' . mysql_error()); 
  8. $sql = 'DELETE FROM tutorials_tbl 
  9.         WHERE tutorial_id=3'; 
  10. //by /mysql 
  11. mysql_select_db('TUTORIALS'); 
  12. $retval = mysql_query( $sql$conn ); 
  13. if(! $retval ) 
  14.   die('Could not delete data: ' . mysql_error()); 
  15. echo "Deleted data successfullyn"
  16. mysql_close($conn); 
  17. ?>

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表