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

SEO探索者团队 SEO服务&网站优化

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

MySQL数据插入

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

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

  1. INSERTINTOtable_name(field1,field2,...fieldN)VALUES(value1,value2,...valueN);

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

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

  1. root@host#mysql-uroot-ppassword;
  2. Enterpassword:*******
  3. mysql>useTUTORIALS;
  4. Databasechanged
  5. mysql>INSERTINTOtutorials_tbl
  6. ->(tutorial_title,tutorial_author,submission_date)
  7. ->VALUES
  8. ->("LearnPHP","JohnPoul",NOW());
  9. QueryOK,1rowaffected(0.01sec)
  10. mysql>INSERTINTOtutorials_tbl
  11. ->(tutorial_title,tutorial_author,submission_date)
  12. ->VALUES--phpfensi.com
  13. ->("LearnMySQL","AbdulS",NOW());
  14. QueryOK,1rowaffected(0.01sec)
  15. mysql>INSERTINTOtutorials_tbl
  16. ->(tutorial_title,tutorial_author,submission_date)
  17. ->VALUES
  18. ->("JAVATutorial","Sanjay",'2007-05-06');
  19. QueryOK,1rowaffected(0.01sec)
  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>AddNewRecordinMySQLDatabase-by/mysql</title>
  4. </head>
  5. <body>
  6. <?php
  7. if(isset($_POST['add']))
  8. {
  9. $dbhost='localhost:3036';
  10. $dbuser='root';
  11. $dbpass='rootpassword';
  12. $conn=mysql_connect($dbhost,$dbuser,$dbpass);
  13. if(!$conn)
  14. {
  15. die('Couldnotconnect:'.mysql_error());
  16. }
  17. if(!get_magic_quotes_gpc())
  18. {
  19. $tutorial_title=addslashes($_POST['tutorial_title']);
  20. $tutorial_author=addslashes($_POST['tutorial_author']);
  21. }
  22. else
  23. {
  24. $tutorial_title=$_POST['tutorial_title'];
  25. $tutorial_author=$_POST['tutorial_author'];
  26. }
  27. $submission_date=$_POST['submission_date'];
  28. $sql="INSERTINTOtutorials_tbl".
  29. "(tutorial_title,tutorial_author,submission_date)".
  30. "VALUES".
  31. "('$tutorial_title','$tutorial_author','$submission_date')";
  32. mysql_select_db('TUTORIALS');
  33. $retval=mysql_query($sql,$conn);
  34. if(!$retval)
  35. {
  36. die('Couldnotenterdata:'.mysql_error());
  37. }
  38. echo"Entereddatasuccessfullyn";
  39. mysql_close($conn);
  40. }
  41. else
  42. {
  43. ?>
  44. <formmethod="post"action="<?php$_PHP_SELF?>">
  45. <tablewidth="600"border="0"cellspacing="1"cellpadding="2">
  46. <tr>
  47. <tdwidth="250">TutorialTitle</td>
  48. <td>
  49. <inputname="tutorial_title"type="text"id="tutorial_title">
  50. </td>
  51. </tr>
  52. <tr>
  53. <tdwidth="250">TutorialAuthor</td>
  54. <td>
  55. <inputname="tutorial_author"type="text"id="tutorial_author">
  56. </td>
  57. </tr>
  58. <tr>
  59. <tdwidth="250">SubmissionDate[yyyy-mm-dd]</td>
  60. <td>
  61. <inputname="submission_date"type="text"id="submission_date">
  62. </td>
  63. </tr>
  64. <tr>
  65. <tdwidth="250"></td>
  66. <td></td>
  67. </tr>
  68. <tr>
  69. <tdwidth="250"></td>
  70. <td>
  71. <inputname="add"type="submit"id="add"value="AddTutorial">
  72. </td>
  73. </tr>
  74. </table>
  75. </form>
  76. <?php
  77. }
  78. ?>
  79. </body>
  80. </html>

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

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

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

  1. SELECTfield1,field2,...fieldNtable_name1,table_name2...
  2. [WHEREClause]
  3. [OFFSETM][LIMITN]

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

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

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

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

  1. root@host#mysql-uroot-ppassword;
  2. Enterpassword:*******
  3. mysql>useTUTORIALS;
  4. Databasechanged
  5. mysql>SELECT*fromtutorials_tbl
  6. +-------------+----------------+-----------------+-----------------+
  7. |tutorial_id|tutorial_title|tutorial_author|submission_date|
  8. +-------------+----------------+-----------------+-----------------+
  9. |1|LearnPHP|JohnPoul|2007-05-21|
  10. |2|LearnMySQL|AbdulS|2007-05-21|
  11. |3|JAVATutorial|Sanjay|2007-05-21|
  12. +-------------+----------------+-----------------+-----------------+
  13. 3rowsinset(0.01sec)
  14. 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. {
  8. die('Couldnotconnect:'.mysql_error());
  9. }
  10. $sql='SELECTtutorial_id,tutorial_title,
  11. tutorial_author,submission_date
  12. FROMtutorials_tbl';
  13. mysql_select_db('TUTORIALS');
  14. $retval=mysql_query($sql,$conn);
  15. if(!$retval)
  16. {
  17. die('Couldnotgetdata:'.mysql_error());
  18. }
  19. while($row=mysql_fetch_array($retval,MYSQL_ASSOC))
  20. {
  21. echo"TutorialID:{$row['tutorial_id']}<br>".
  22. "Title:{$row['tutorial_title']}<br>".
  23. "Author:{$row['tutorial_author']}<br>".
  24. "SubmissionDate:{$row['submission_date']}<br>".
  25. "--------------------------------<br>";
  26. }
  27. echo"Fetcheddatasuccessfullyn";
  28. mysql_close($conn);
  29. ?>

这些行的内容被分配到变量$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. {
  8. die('Couldnotconnect:'.mysql_error());
  9. }
  10. $sql='SELECTtutorial_id,tutorial_title,
  11. tutorial_author,submission_date
  12. FROMtutorials_tbl';
  13. mysql_select_db('TUTORIALS');
  14. $retval=mysql_query($sql,$conn);
  15. if(!$retval)
  16. {
  17. die('Couldnotgetdata:'.mysql_error());
  18. }
  19. while($row=mysql_fetch_assoc($retval))
  20. {
  21. echo"TutorialID:{$row['tutorial_id']}<br>".
  22. "Title:{$row['tutorial_title']}<br>".
  23. "Author:{$row['tutorial_author']}<br>".
  24. "SubmissionDate:{$row['submission_date']}<br>".
  25. "--------------------------------<br>";
  26. }
  27. echo"Fetcheddatasuccessfullyn";
  28. mysql_close($conn);
  29. ?>

也可以使用常量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. {
  8. die('Couldnotconnect:'.mysql_error());
  9. }
  10. $sql='SELECTtutorial_id,tutorial_title,
  11. tutorial_author,submission_date
  12. FROMtutorials_tbl';
  13. mysql_select_db('TUTORIALS');
  14. $retval=mysql_query($sql,$conn);
  15. if(!$retval)
  16. {
  17. die('Couldnotgetdata:'.mysql_error());
  18. }
  19. while($row=mysql_fetch_array($retval,MYSQL_NUM))
  20. {
  21. echo"TutorialID:{$row[0]}<br>".
  22. "Title:{$row[1]}<br>".
  23. "Author:{$row[2]}<br>".
  24. "SubmissionDate:{$row[3]}<br>".
  25. "--------------------------------<br>";
  26. }
  27. echo"Fetcheddatasuccessfullyn";
  28. mysql_close($conn);
  29. ?>

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

释放内存:它是一种很好的做法,在每一个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. {
  8. die('Couldnotconnect:'.mysql_error());
  9. }
  10. $sql='SELECTtutorial_id,tutorial_title,
  11. tutorial_author,submission_date
  12. FROMtutorials_tbl';
  13. mysql_select_db('TUTORIALS');
  14. $retval=mysql_query($sql,$conn);
  15. if(!$retval)
  16. {
  17. die('Couldnotgetdata:'.mysql_error());
  18. }
  19. while($row=mysql_fetch_array($retval,MYSQL_NUM))
  20. {
  21. echo"TutorialID:{$row[0]}<br>".
  22. "Title:{$row[1]}<br>".
  23. "Author:{$row[2]}<br>".
  24. "SubmissionDate:{$row[3]}<br>".
  25. "--------------------------------<br>";
  26. }
  27. mysql_free_result($retval);
  28. echo"Fetcheddatasuccessfullyn";
  29. mysql_close($conn);
  30. ?>

在获取数据的同时可以编写复杂的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-uroot-ppassword;
  2. Enterpassword:*******
  3. mysql>useTUTORIALS;
  4. Databasechanged
  5. mysql>DELETEFROMtutorials_tblWHEREtutorial_id=3;
  6. QueryOK,1rowaffected(0.23sec)
  7. 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. {
  8. die('Couldnotconnect:'.mysql_error());
  9. }
  10. $sql='DELETEFROMtutorials_tbl
  11. WHEREtutorial_id=3';
  12. //by/mysql
  13. mysql_select_db('TUTORIALS');
  14. $retval=mysql_query($sql,$conn);
  15. if(!$retval)
  16. {
  17. die('Couldnotdeletedata:'.mysql_error());
  18. }
  19. echo"Deleteddatasuccessfullyn";
  20. mysql_close($conn);
  21. ?>

相关广告
  • MySQL数据插入 查询 删除语句详解 MySQL数据插入 查询 删除语句详解 MySQL数据插入 查询 删除语句详解
相关阅读

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

2019/10/10 17:36:17 | 谷歌SEO算法 | 微服务