SQLite - WHERE子句
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
最新文章
- linux 学习 13 系统管理
- ERROR 1018 (HY000): Can&#39;t read dir of &#39;./test/&#39; (errno: 13)
- 匿名函数和Lamda
- POJ 3176 简单DP
- 编写高质量JS代码的68个有效方法(三)
- css3实现动态圆形导航栏
- 泥泞的道路(codevs 1183)
- Java基础(34):Java中基本数据类型的包装类(主要为了不同数据类型之间更方便的进行转换)(Wrapper类)
- AX 获得当前Grid的数据源的记录行数
- linux中创建静态库和动态库
- 工作中小知识点汇总(sql)
- TIA Portal V12不能添加新的CPU
- Windows Phone开发(1):概论
- leetcode第37题--Count and Say
- Inno ;Setup技巧[界面]欢迎页面上添加文字
- android的签名
- hdu_1012(水题。。。不能再水)
- Github提交本地代码
- 解决跨域脚本攻击 XSS
- SQLServer 2008以上误操作数据库恢复方法—日志尾部备份
热门文章
- sql添加表
- Linux环境下Nginx及负载均衡
- bzoj 4032: [HEOI2015]最短不公共子串【dp+SAM】
- P5136 sequence(矩阵快速幂)
- Source Insight 入门设置
- C#求圆的周长、面积、体积
- 笔记-JavaWeb学习之旅6
- Mysql字符串截取总结及项目实际运用:left()、right()、substring()、substring_index()
- CentOS(6、7)修改主机名(hostname)
- Excel - 使用公式将秒转换为分+秒