详解MySQL中WHERE子句的用法

 更新时间:2015年05月26日 11:59:50   投稿:goldensun  
这篇文章主要介绍了详解MySQL中WHERE子句的用法,是MySQL入门学习中的基础知识,需要的朋友可以参考下

我们已经看到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:

2015526115818593.jpg (850×259)

 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']} <br> ".
     "Title: {$row['tutorial_title']} <br> ".
     "Author: {$row['tutorial_author']} <br> ".
     "Submission Date : {$row['submission_date']} <br> ".
     "--------------------------------<br>";
} 
echo "Fetched data successfully\n";
mysql_close($conn);
?>

相关文章

  • mysql 8.0.11 安装步骤详解

    mysql 8.0.11 安装步骤详解

    这篇文章主要为大家详细介绍了mysql 8.0.11 安装步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Mysql查询优化的一些实用方法总结

    Mysql查询优化的一些实用方法总结

    对于MySQL查询语句来说,效率是最重要的,下面这篇文章主要给大家介绍了关于Mysql查询优化的一些实用方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • CentOS 7安装MySQL的详细步骤

    CentOS 7安装MySQL的详细步骤

    这篇文章主要为大家介绍了CentOS 7安装MySQL的详细步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • MySQL命令提示符出现输入错误时如何修改前面的命令

    MySQL命令提示符出现输入错误时如何修改前面的命令

    本文主要介绍了MySQL命令提示符出现输入错误时如何修改前面的命令,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • mysql中的replace函数替换字符串问题

    mysql中的replace函数替换字符串问题

    这篇文章主要介绍了mysql中的replace函数替换字符串问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 一次MySQL启动导致的事故实战记录

    一次MySQL启动导致的事故实战记录

    这篇文章主要给大家介绍了一次MySQL启动导致的事故实战记录,记录了MySQL 启动成功但未监听端口的解决方法,文中给出了详细的解决方法,需要的朋友可以参考下
    2021-09-09
  • RHEL6.5编译安装MySQL5.6.26教程

    RHEL6.5编译安装MySQL5.6.26教程

    这篇文章主要介绍了RHEL6.5编译安装MySQL5.6.26教程的相关资料,需要的朋友可以参考下
    2015-10-10
  • CentOS6.5下RPM方式安装mysql5.6.33的详细教程

    CentOS6.5下RPM方式安装mysql5.6.33的详细教程

    本文给大家详细介绍CentOS6.5下RPM方式安装mysql5.6.33的教程,本文分步骤给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友一起看看吧
    2016-10-10
  • 详解MySQL到SelectDB的实时同步策略

    详解MySQL到SelectDB的实时同步策略

    MySQL 到 SelectDB 的实时数据同步技术,通过 NineData 的数据复制控制台,仅需轻点鼠标,即可轻松完成 MySQL 到 SelectDB 的同步任务配置,这篇文章主要介绍了MySQL到SelectDB的实时同步策略,需要的朋友可以参考下
    2023-09-09
  • mysql count()函数不计算null和空值问题

    mysql count()函数不计算null和空值问题

    这篇文章主要介绍了mysql count()函数不计算null和空值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08

最新评论