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

最新文章

  1. linux 学习 13 系统管理
  2. ERROR 1018 (HY000): Can&#39;t read dir of &#39;./test/&#39; (errno: 13)
  3. 匿名函数和Lamda
  4. POJ 3176 简单DP
  5. 编写高质量JS代码的68个有效方法(三)
  6. css3实现动态圆形导航栏
  7. 泥泞的道路(codevs 1183)
  8. Java基础(34):Java中基本数据类型的包装类(主要为了不同数据类型之间更方便的进行转换)(Wrapper类)
  9. AX 获得当前Grid的数据源的记录行数
  10. linux中创建静态库和动态库
  11. 工作中小知识点汇总(sql)
  12. TIA Portal V12不能添加新的CPU
  13. Windows Phone开发(1):概论
  14. leetcode第37题--Count and Say
  15. Inno&nbsp;Setup技巧[界面]欢迎页面上添加文字
  16. android的签名
  17. hdu_1012(水题。。。不能再水)
  18. Github提交本地代码
  19. 解决跨域脚本攻击 XSS
  20. SQLServer 2008以上误操作数据库恢复方法—日志尾部备份

热门文章

  1. sql添加表
  2. Linux环境下Nginx及负载均衡
  3. bzoj 4032: [HEOI2015]最短不公共子串【dp+SAM】
  4. P5136 sequence(矩阵快速幂)
  5. Source Insight 入门设置
  6. C#求圆的周长、面积、体积
  7. 笔记-JavaWeb学习之旅6
  8. Mysql字符串截取总结及项目实际运用:left()、right()、substring()、substring_index()
  9. CentOS(6、7)修改主机名(hostname)
  10. Excel - 使用公式将秒转换为分+秒