mysql的where用法_详解MySQL中WHERE子句的用法

我们已经看到SQL SELECT命令来从MySQL表获取数据。我们可以使用一个条件子句WHERE子句中筛选出来的结果。使用WHERE子句,我们可以指定一个选择的标准来从表中选择所需的记录。

语法:

下面是通用的SQL WHERE子句来获取数据从MySQL表的SELECT命令的语法: SELECT field1, field2,...fieldN table_name1, table_name2...

[WHERE condition1 [AND [OR]] condition2..... 可以使用一个或多个以逗号分隔的表,包括各种使用WHERE子句条件。但是WHERE子句的SELECT命令是一个可选部分。 您可以使用WHERE子句指定任何条件。 您可以指定一个以上的条件下使用AND或者OR运算符。 一个WHERE子句中可以使用的分散DELETE或UPDATE的SQL命令指定条件。

就像编程语言中的一样,如果条件的WHERE子句。该子句用于在MySQL的表的字段值与给定值比较。如果从外部给定值是等于可用字段值在MySQL表,然后返回该行。

这里是清单的运算符可以使用WHERE子句。

假设字段A有值为10和字段B拥有的值为20:

53e51f4a4356d2461e83133ac12db391.png

WHERE子句是非常有用的,当想获取的选择表中的行,特别是当你使用MySQL的JOIN。JOIN在另一章中讨论。

这是一个常见的做法是使用主键查找记录,使搜索快速。

如果给定的条件不符合任何表中的记录,那么查询不会返回任何行。

从命令提示符获取数据:

这将使用SQL SELECT命令的WHERE子句,以获取选择的数据MySQL表tutorials_tbl

实例:

下面的例子将返回tutorials_tbl表中作者的名字是Sanjay所有记录: root@host# mysql -u root -p password;

Enter password:*******

mysql> use TUTORIALS;

Database changed

mysql> SELECT * from tutorials_tbl WHERE tutorial_author='Sanjay';

+-------------+----------------+-----------------+-----------------+

| tutorial_id | tutorial_title | tutorial_author | submission_date |

+-------------+----------------+-----------------+-----------------+

| 3 | JAVA Tutorial | Sanjay | 2007-05-21 |

+-------------+----------------+-----------------+-----------------+

1 rows in set (0.01 sec)

mysql>

除非执行LIKE比较字符串的比较是不区分大小写的。可以搜索区分大小写,使用BINARY关键字如下。 root@host# mysql -u root -p password;

Enter password:*******

mysql> use TUTORIALS;

Database changed

mysql> SELECT * from tutorials_tbl \

WHERE BINARY tutorial_author='sanjay';

Empty set (0.02 sec)

mysql>

使用PHP脚本获取数据:

可以使用相同SQL的SELECT命令的WHERE子句中到PHP的functionmysql_query()中。这个函数是用来执行SQL命令后,另一个PHP函数mysql_fetch_array()可以用来获取所有选定的数据。这个函数返回的行作为一个关联数组,数字数组或两者。这个函数返回FALSE,如果没有更多的行。

实例:

下面的例子将返回tutorials_tbl表中作者的名字是Sanjay所有记录: <?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

WHERE tutorial_author="Sanjay"';

//by www.jb51.net

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']}
".

"Title: {$row['tutorial_title']}
".

"Author: {$row['tutorial_author']}
".

"Submission Date : {$row['submission_date']}
".

"--------------------------------
";

}

echo "Fetched data successfully\n";

mysql_close($conn);

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQLupdate语句是用来修改表格已有的记录。其基本语法如下: ``` UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition; ``` 其,`table_name`为表格名,`column1`、`column2`等是需要修改的列名,`value1`、`value2`等是相应列名要被修改成的值。`WHERE`子句为可选项,但它的作用是筛选需要被修改的数据,因此通常需要使用。 例如,当我们需要在表格`students`将`score`列大于80的分数修改为100时,可以使用以下update语句: ``` UPDATE students SET score = 100 WHERE score > 80; ``` 此外,在update语句我们还可以使用一些其他的关键字进行特殊操作。以下是几个常用的关键字: - `LIMIT`:用于限制改动的记录数。例如,`UPDATE students SET score = 100 WHERE score > 80 LIMIT 3;`表示只修改满足条件的前3条记录。 - `ORDER BY`:用于对筛选出的数据进行排序。例如,`UPDATE students SET score = 100 WHERE score > 80 ORDER BY score DESC;`表示按分数从高到低排序后,将符合条件的记录的分数修改为100。 - `JOIN`:用于在一个update语句同时操作多张表格。例如,`UPDATE students AS s JOIN courses ON s.id = courses.id SET s.score = 90 WHERE courses.name = 'Math';`表示修改选了数学课的学生的分数为90。此处`s`为`students`表格的别名。 在使用update语句时需要小心操作,确保修改的数据与条件无误。同时,由于update语句将直接修改表格的记录,因此也需要充分备份原有数据以防操作失误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值