SQLite - WHERE子句

SQLite WHERE子句用于指定一个条件同时抓取数据从一个表或多个表。    

如果给定的条件满意,意味着true,然后从表中返回特定值。你会使用WHERE子句来筛选记录,只获取必要的记录。    

WHERE子句不仅用于SELECT语句,但它也用于更新、删除语句,等等,我们将在后续章节的研究。

语句

SQLite SELECT语句的WHERE子句的基本语法如下:

SELECT column1, column2, columnN

FROM table_name

WHERE [condition]

例子

您可以指定一个条件使用比较或逻辑运算符>、<、=,,等。考虑公司表有以下记录:

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

以下是简单的例子显示使用SQLite逻辑运算符。下列SELECT语句列表下的所有记录,年龄大于或等于25和工资是大于且等于65000.00:

sqlite> SELECT * FROM COMPANY WHERE AGE >=25 AND SALARY >=65000;

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

4Mark25Rich-Mond65000.0

5David27Texas85000.0

下列SELECT语句列表下的所有记录,年龄大于或等于25或工资是大于或等于65000.00:

sqlite> SELECT * FROM COMPANY WHERE AGE >=25 OR SALARY >=65000;

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

1Paul32California20000.0

2Allen25Texas15000.0

4Mark25Rich-Mond65000.0

5David27Texas85000.0

下列SELECT语句列表下的所有记录,年龄并不是空这意味着所有的记录,因为没有记录的年龄等于零:

sqlite> SELECT * FROM COMPANY WHERE AGE IS NOT NULL;

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

1Paul32California20000.0

2Allen25Texas15000.0

3Teddy23Norway20000.0

4Mark25Rich-Mond65000.0

5David27Texas85000.0

6Kim22South-Hall45000.0

7James24Houston10000.0

下列SELECT语句列表下的所有记录名称始于"ki","ki"后是什么并不重要。

sqlite> SELECT * FROM COMPANY WHERE NAME LIKE 'Ki%';

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

6Kim22South-Hall45000.0

下列SELECT语句列表下的所有记录名称始于"ki","ki"后是什么并不重要。

sqlite> SELECT * FROM COMPANY WHERE NAME GLOB 'Ki*';

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

6Kim22South-Hall45000.0

下列SELECT语句列表下的所有记录年龄值为25或27:

sqlite> SELECT * FROM COMPANY WHERE AGE IN (25,27);

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

2Allen25Texas15000.0

4Mark25Rich-Mond65000.0

5David27Texas85000.0

下列SELECT语句列表下的所有记录的年龄值不是25和27:

sqlite> SELECT * FROM COMPANY WHERE AGE NOT IN (25,27);

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

1Paul32California20000.0

3Teddy23Norway20000.0

6Kim22South-Hall45000.0

7James24Houston10000.0

下列SELECT语句列表下的所有记录,年龄25 - 27之间:

sqlite> SELECT * FROM COMPANY WHERE AGE BETWEEN 25 AND 27;

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

2Allen25Texas15000.0

4Mark25Rich-Mond65000.0

5David27Texas85000.0

SELECT语句利用SQL查询,子查询后发现所有记录年龄字段有工资> 65000,后来使用where子句以及存在运营商列表下的所有记录,年龄从外部查询存在于子查询返回的结果:

sqlite> SELECT AGE FROM COMPANY

WHERE EXISTS (SELECT AGE FROM COMPANY WHERE SALARY >65000);

AGE

----------

32

25

23

25

27

22

24

SELECT语句利用SQL查询,子查询后发现所有记录年龄字段有工资> 65000,后来一起使用where子句>操作符列表下来年龄以外的所有记录查询年龄大于子查询返回的结果:

sqlite> SELECT * FROM COMPANY

WHERE AGE >(SELECT AGE FROM COMPANY WHERE SALARY >65000);

ID NAME AGE ADDRESS SALARY

--------------------------------------------------

1Paul32California20000.0

SQLite - WHERE子句的更多相关文章

  1. SQLite Where 子句(http://www.w3cschool.cc/sqlite/sqlite-where-clause.html)

    SQLite Where 子句 SQLite的 WHERE 子句用于指定从一个表或多个表中获取数据的条件. 如果满足给定的条件,即为真(true)时,则从表中返回特定的值.您可以使用 WHERE 子句 ...

  2. SQLite – GLOB子句

    SQLite – GLOB子句 .与LIKE不同,GLOB是大小写敏感的,它遵循语法的UNIX指定以下通配符. The asterisk sign (*) The question mark (?) ...

  3. SQLite – LIMIT子句

    SQLite - LIMIT子句 SQLite LIMIT子句是用来限制SELECT语句返回的数据量. 语法: SELECT语句.LIMIT子句的基本语法如下: SELECT column1, col ...

  4. SQLite – HAVING 子句

    SQLite – HAVING子句 HAVING使您能够指定过滤条件哪一组结果出现在最终的结果. WHERE子句的地方条件选定的列, 在有HAVING 子句的地方 就有GROUP BY子句包含的条件组 ...

  5. SQLite – ORDER 子句

    SQLite - ORDER BY子句 The SQLite ORDER BY子句用于数据按升序或降序排序,基于一个或多个列. 语法: ORDER BY子句的基本语法如下: SELECT column ...

  6. SQLite的基本使用

    SQLite 创建表 SQLite 的 CREATE TABLE 语句用于在任何给定的数据库创建一个新表.创建基本表,涉及到命名表.定义列及每一列的数据类型. 语法 CREATE TABLE 语句的基 ...

  7. 学习SQLite之路(三)

    20160616更新 参考: http://www.runoob.com/sqlite/sqlite-tutorial.html 1. SQLite  PRAGMA:可以用在 SQLite 环境内控制 ...

  8. 学习SQLite之路(二)

    下面就是真正关于数据库的一些知识了: 20160614更新 参考: http://www.runoob.com/sqlite/sqlite-tutorial.html 1. SQLite创建表: 基本 ...

  9. Android-adb 常用命令 和 sqlite

    Android开发环境中,ADB是我们进行Android开发经常要用的调试工具,它的使用当然是我们Android开发者必须要掌握的. ADB概述 Android Debug Bridge,Androi ...

随机推荐

  1. 1.6-1.8 HBase表的物理模型

    一.HBase 物理模型 1. 1.Table中的所有行都按照row key的字典序排列: 2.Table在行的方向上分割为多个Region: 3.Region按天小分割的,每个表开始只有一个regi ...

  2. CodeForces - 566D Restructuring Company 并查集的区间合并

    Restructuring Company Even the most successful company can go through a crisis period when you have ...

  3. Flink on Yarn模式启动流程源代码分析

    此文已由作者岳猛授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. Flink on yarn的启动流程可以参见前面的文章 Flink on Yarn启动流程,下面主要是从源码角 ...

  4. E20181001-ts

    decorate vt. 装饰; 点缀; 粉刷; 授予(某人)勋章  vi. 装饰; 布置;

  5. HDU 1556【线段树区间更新】

    这篇lazy讲的很棒: https://www.douban.com/note/273509745/ if(tree[rt].l == l && r == tree[rt].r) 这里 ...

  6. 2012 Noip提高组 Day1

    1262. [NOIP2012] Vigenère 密码 ★   输入文件:vigenere.in   输出文件:vigenere.out   简单对比时间限制:1 s   内存限制:128 MB [ ...

  7. 在mpvue框架中使用Vant WeappUI组件库的注意事项

    1如何引入组件库 有两种方法 1 npm下载 2 下载代码,下面介绍第二种方法. 在gitHub上, 链接如下 https://github.com/youzan/vant-weapp 首先在自己项目 ...

  8. 类的property特性

    目录 什么是 property特性 简单示例 property属性的两种方式 装饰器 类属性方式 property+类的封装 应用 私有属性添加getter和setter方法 使用property升级 ...

  9. Promise对象深入理解

     目录 基本用法 返回另一个 Promise 实例 Promise.prototypeof.then Promise.prototype.catch Promise.prototype.finally ...

  10. Java 分析工具汇总

    http://blog.csdn.net/fenglibing/article/details/6411999 jps  jps -mlvV jmap jmap -heap <pid>   ...