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

MySQL数据插入

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

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

 代码如下 复制代码
INSERT INTO table_name ( field1, field2,...fieldN )
                       VALUES
                       ( value1, value2,...valueN );

要插入的字符串数据类型,所有的值需要双或单引号,例如: - “value”。

从命令提示符中插入数据:
这将使用SQL INSERT INTO命令将数据插入到MySQL表tutorials_tbl

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

 代码如下 复制代码
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> INSERT INTO tutorials_tbl
     ->(tutorial_title, tutorial_author, submission_date)
     ->VALUES
     ->("Learn PHP", "John Poul", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
     ->(tutorial_title, tutorial_author, submission_date)
     ->VALUES
     ->("Learn MySQL", "Abdul S", NOW());
Query OK, 1 row affected (0.01 sec)
mysql> INSERT INTO tutorials_tbl
     ->(tutorial_title, tutorial_author, submission_date)
     ->VALUES
     ->("JAVA Tutorial", "Sanjay", '2007-05-06');
Query OK, 1 row affected (0.01 sec)
mysql>

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

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

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

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

 代码如下 复制代码

<html>
<head>
<title>Add New Record in MySQL Database -by /mysql</title>
</head>
<body>
<?php
if(isset($_POST['add']))
{
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}

if(! get_magic_quotes_gpc() )
{
   $tutorial_title = addslashes ($_POST['tutorial_title']);
   $tutorial_author = addslashes ($_POST['tutorial_author']);
}
else
{
   $tutorial_title = $_POST['tutorial_title'];
   $tutorial_author = $_POST['tutorial_author'];
}
$submission_date = $_POST['submission_date'];

$sql = "INSERT INTO tutorials_tbl ".
       "(tutorial_title,tutorial_author, submission_date) ".
       "VALUES ".
       "('$tutorial_title','$tutorial_author','$submission_date')";
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not enter data: ' . mysql_error());
}
echo "Entered data successfullyn";
mysql_close($conn);
}
else
{
?>
<form method="post" action="<?php $_PHP_SELF ?>">
<table width="600" border="0" cellspacing="1" cellpadding="2">
<tr>
<td width="250">Tutorial Title</td>
<td>
<input name="tutorial_title" type="text" id="tutorial_title">
</td>
</tr>
<tr>
<td width="250">Tutorial Author</td>
<td>
<input name="tutorial_author" type="text" id="tutorial_author">
</td>
</tr>
<tr>
<td width="250">Submission Date [ yyyy-mm-dd ]</td>
<td>
<input name="submission_date" type="text" id="submission_date">
</td>
</tr>
<tr>
<td width="250"> </td>
<td> </td>
</tr>
<tr>
<td width="250"> </td>
<td>
<input name="add" type="submit" id="add" value="Add Tutorial">
</td>
</tr>
</table>
</form>
<?php
}
?>
</body>
</html>

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

MySQL数据查询

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

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

 代码如下 复制代码
SELECT field1, field2,...fieldN table_name1, table_name2...
[WHERE Clause]
[OFFSET M ][LIMIT N]

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

可以在一个单一的SELECT命令读取一个或多个字段。

可以指定星号(*)的字段的地方。在这种情况下,SELECT将返回所有的字段

可以使用WHERE子句指定任何条件。

可以指定偏移用SELECT将开始返回记录的偏移量。默认情况下,偏移量为0

可以限制返回的使用LIMIT属性的数量。

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

例子:
下面的例子将返回所有记录tutorials_tbl表:

 代码如下 复制代码

root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from tutorials_tbl
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
|           1 | Learn PHP      | John Poul       | 2007-05-21      |
|           2 | Learn MySQL    | Abdul S         | 2007-05-21      |
|           3 | JAVA Tutorial  | Sanjay          | 2007-05-21      |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.01 sec)

mysql>

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

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

例子:
试试下面的例子显示tutorials_tbl表的所有记录。

 代码如下 复制代码

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title,
               tutorial_author, submission_date
        FROM tutorials_tbl';

mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC))
{
    echo "Tutorial ID :{$row['tutorial_id']}  <br> ".
         "Title: {$row['tutorial_title']} <br> ".
         "Author: {$row['tutorial_author']} <br> ".
         "Submission Date : {$row['submission_date']} <br> ".
         "--------------------------------<br>";
}
echo "Fetched data successfullyn";
mysql_close($conn);
?>

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

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

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

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

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

 代码如下 复制代码

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title,
               tutorial_author, submission_date
        FROM tutorials_tbl';

mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_assoc($retval))
{
    echo "Tutorial ID :{$row['tutorial_id']}  <br> ".
         "Title: {$row['tutorial_title']} <br> ".
         "Author: {$row['tutorial_author']} <br> ".
         "Submission Date : {$row['submission_date']} <br> ".
         "--------------------------------<br>";
}
echo "Fetched data successfullyn";
mysql_close($conn);
?>

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

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

 代码如下 复制代码

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title,
               tutorial_author, submission_date
        FROM tutorials_tbl';

mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_NUM))
{
    echo "Tutorial ID :{$row[0]}  <br> ".
         "Title: {$row[1]} <br> ".
         "Author: {$row[2]} <br> ".
         "Submission Date : {$row[3]} <br> ".
         "--------------------------------<br>";
}
echo "Fetched data successfullyn";
mysql_close($conn);
?>

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

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

实例:
试试下面的例子

 代码如下 复制代码

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT tutorial_id, tutorial_title,
               tutorial_author, submission_date
        FROM tutorials_tbl';

mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_NUM))
{
    echo "Tutorial ID :{$row[0]}  <br> ".
         "Title: {$row[1]} <br> ".
         "Author: {$row[2]} <br> ".
         "Submission Date : {$row[3]} <br> ".
         "--------------------------------<br>";
}
mysql_free_result($retval);
echo "Fetched data successfullyn";
mysql_close($conn);
?>

在获取数据的同时可以编写复杂的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的记录。

 代码如下 复制代码

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

mysql>

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

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

 代码如下 复制代码

<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
  die('Could not connect: ' . mysql_error());
}
$sql = 'DELETE FROM tutorials_tbl
        WHERE tutorial_id=3';
//by /mysql
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval )
{
  die('Could not delete data: ' . mysql_error());
}
echo "Deleted data successfullyn";
mysql_close($conn);
?>

时间: 2024-10-29 14:35:54

MySQL数据插入 查询 删除语句详解的相关文章

MySQL数据插入insert性能优化详解

对于一些数据量较大的系统,面临的问题除了是查询效率低下,还有一个很重要的问题就是插入时间长.我们就有一个业务系统,每天的数据导入需要4-5个钟.这种费时的操作其实是很有风险的,假设程序出了问题,想重跑操作那是一件痛苦的事情.因此,提高大数据量系统的MySQL insert效率是很有必要的. 经过对MySQL的测试,发现一些可以提高insert效率的方法,供大家参考参考. 1. 一条SQL语句插入多条数据. 常用的插入语句如:  代码如下 复制代码 INSERTINTO`insert_table`

MySQL用户管理及SQL语句详解

1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysql.user; +--------+------------+-------------------------------------------+ | user | host | password | +--------+------------+-------------------------------------------+ | r

Mysql 插入记录 instert语句详解

Mysql 语句之 插入记录 instert 单行插入  代码如下 复制代码 insert into 表名(字段名,字段名, - ) values( 字段值,字段值,-); insert into A(A_e,A_f,A_a) values('字符',10,01); 多行插入  代码如下 复制代码 insert into 表名 values( 字段值,字段值,-),( 字段值,字段值,-); insert into A values('字符',10,01),('字符',10,01);   插入记

mysql 去除重复记录sql语句详解

SQL SELECT DISTINCT 语句 语法: SELECT DISTINCT 列名称 FROM 表名称使用 DISTINCT 关键词 如果要从 "Company" 列中选取所有的值,我们需要使用 SELECT 语句: SELECT Company FROM Orders 如需从 Company" 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:  代码如下 复制代码 SELECT DISTINCT Company FROM Orders 下

MySQL Left Join,Right Join语句详解

在SQL标准中规划的(Join)联结大致分为下面四种: 1. 内联结:将两个表中存在联结关系的字段符合联结关系的那些记录形成记录集的联结. 2. 外联结:分为外左联结和外右联结. 左联结A.B表的意思就是将表A中的全部记录和表B中联结的字段与表A的联结字段符合联结条件的那些记录形成的记录集的联结,这里注意的是最后出来的记录集会包括表A的全部记录. 右联结A.B表的结果和左联结B.A的结果是一样的,也就是说:  代码如下 复制代码 Select A.name B.name From A Left

MySQL slow_query_log慢查询日志配置详解

slow_query_log是记录SQL执行超过一定时间的参数. slow query log相关变量 1.命令行参数:     --log-slow-queries     指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log 2.系统变量     log_slow_queries     指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log     slow_query_log     slow quere log的

MySQL数据入库时特殊字符处理详解_Mysql

在一个字符串中,如果某个序列具有特殊的含义,每个序列以反斜线符号 ("")开头,称为转义字符. MySQL 识别下列转义字符: 0 一个 ASCII 0 (NUL) 字符. ' 一个 ASCII 39 单引号 ("'") 字符. " 一个 ASCII 34 双引号 (""") 字符. 一个 ASCII 8 退格符. 一个 ASCII 10 换行符. r 一个 ASCII 13 回车符. t 一个 ASCII 9 制表符(TAB

Mysql左连接sql left join 语句详解

mysql教程左连接sql left join 语句详解 mysql左连接查询是联合查询中的一种方式,就是说把两个相关的表通过这种方式联合在一起查询,从而更加方便调用数据,避免多层循环嵌套. 左连接查询所用关键字 left join ,书面解释如下:   左外连接(左连接):结果集既包括连接表的匹配行,也包括左连接表的所有行. 下面我解释一下,也就是说左链接查询的返回结果既包含了left join关键字左边表的全部资料,同时也包含了与左表匹配的右表中的符合条件的资源. 简单的说就是以左表为中心,

MySql绿色版配置及使用详解

原文:MySql绿色版配置及使用详解           最近在做项目开发时用到了MySql数据库,在看了一些有关MySql的文章后,很快就上手使用了.在使用的过程中还是出现了一些问题,因为使用的是绿色免安装版的MySql所以在配置的时候出现了一些问题,该篇文章就主要针对MySql绿色版的配置及其使用进行讨论. 一.MySql概述        MySql数据库是有瑞典MySql AB公司开发,现在该公司被Oracle收购属于Oracle所有.同SQL Server类似,它也是基于关系型数据库的