mysql-3 检索数据(1)
SELECT 语句
SELECT检索表数据,必须至少给出两条信息--------想选择什么,以及从什么地方选择。
检索一个列
SELECT prod_name FROM products;
上述语句利用SELECT语句从products表中检索一个名为prod_name的列

检索多个列
SELECT prod_id,prod_name,prod_price FROM products;

检索所有的列
SELECT * FROM products;

检索不同的行
SELECT vend_id FROM products;

select返回了14行,但是表中只有4个供应商,因为products表中列出了14个产品,如何检索有不同值的列表
SELECT DISTINCT vend_id FROM products;

限制结果
SELECT prod_name FROM products LIMIT 5;

SELECT prod_name FROM products LIMIT 5 , 5;
从第五行开始输出5行
第一个数位开始位置,第二个数为检索的行数

SELECT prod_name FROM products LIMIT 4 OFFSET 3;
从第三行开始,输出四行

使用完全限定输出表名
SELECT products.prod_name FROM products;

排序检索数据
排序数据
SELECT prod_name FROM products ORDER BY prod_name;
mysql对prod_name列以字母顺序排序

按多个排序
SELECT prod_id,prod_price,prod_name FROM products ORDER BY prod_price , prod_name;
首先按照价格然后按照名称排序 作用,当价格相同的时候,会再按照名称来排序。
如果prod_price列中的数据所有值都是唯一的,则不会按照prod_name来排序

制定排序方向
ORDER BY默认是按照升序的方式排列,如果进行降序排列,就必须标出 DESC;
SELECT prod_id , prod_price ,prod_name FROM products ORDER BY prod_price DESC;

SELECT prod_id , prod_price ,prod_name FROM products ORDER BY prod_price DESC, prod_name;
先按照价格从高到底排序,价格相同的再按照名称升序排列。

与DESC相反的是ASC,ASC没有多大作用,因为默认就是ASC升序排列。
SELECT prod_price FROM products ORDER BY prod_price DESC LIMIT 2;
找出两个最贵的物品的值

过滤数据
使用where子句
SELECT prod_name ,prod_price FROM products WHERE prod_price = 2.50;
查询价格等于2.50的商品名字和价格

| 操作符 | 说明 |
| = | 等于 |
| <> | 不等于 |
| != | 不等于 |
| < | 小于 |
| > | 大于 |
| <= | 小于等于 |
| >= | 大于等于 |
| BETWEEN | 在制定的两个值之间 |
检查单个值
SELECT prod_name ,prod_price FROM products WHERE prod_name = 'fuses';

SELECT prod_name,prod_price FROM products WHERE prod_price <10;

SELECT vend_id , prod_name FROM products WHERE vend_id <> 1003;
查询供应商不是1003制造的所有产品

SELECT prod_name , prod_price FROM products WHERE prod_price BETWEEN 5 AND 10;
查询价格在5和之间的商品名称和价格

数据过滤
组合where子句
SELECT prod_id , prod_price ,prod_name FROM products WHERE vend_id =1003 AND prod_price <=10;

SELECT prod_id , prod_price ,prod_name FROM products WHERE vend_id =1002 OR vend_id = 1003;

计算次序
SELECT prod_name , prod_price FROM products WHERE vend_id = 1002 OR vend_id = 1003 AND prod_price >=10;

从上面的结果来看,有两个值的结果小于10,显然返回的结果未按照预期的进行过滤,为什么会这样呢,原因是在于计算的次序,SQL在处理OR操作符前,优先处理AND操作符,当SQL看到上述where子句时,它理解为由供应商1003制造的任何价格都为10美元以上,包含10美元,或者由供应商1002提供的产品,不管价格。换句话说,由于AND的计算次序中优先级更高,操作符被错误的组合了。正确的操作方法:
SELECT prod_name , prod_price FROM products WHERE (vend_id = 1002 OR vend_id = 1003) AND prod_price >=10;

IN 操作符
IN操作符来制定条件范围,范围中的每个条件都可以进行匹配。
SELECT prod_name , prod_price FROM products WHERE vend_id IN (1002,1003) ORDER BY prod_name;

IN和OR的用法有点类似,上面也可以这样写:
SELECT prod_name , prod_price FROM products WHERE vend_id=1002 OR vend_id=1003 ORDER BY prod_name;
NOT操作符
where子句中的not操作符的用法只有一个,那就是否定后它之后所有的任何条件
SELECT prod_name , prod_price FROM products WHERE vend_id NOT IN (1002,1003) ORDER BY prod_name;

上面用到的所有查询命令
SELECT prod_name FROM products;
SELECT prod_id,prod_name,prod_price FROM products;
SELECT * FROM products;
SELECT vend_id FROM products;
SELECT DISTINCT vend_id FROM products;
SELECT prod_name FROM products LIMIT ;
SELECT prod_name FROM products LIMIT , ;
SELECT prod_name FROM products LIMIT , ;
SELECT prod_name FROM products LIMIT OFFSET ;
SELECT products.prod_name FROM products;
SELECT prod_name FROM products ORDER BY prod_name;
SELECT prod_id,prod_price,prod_name FROM products ORDER BY prod_price , prod_name;
SELECT prod_id , prod_price ,prod_name FROM products ORDER BY prod_price DESC;
SELECT prod_id , prod_price ,prod_name FROM products ORDER BY prod_price DESC, prod_name;
SELECT prod_price FROM products ORDER BY prod_price DESC LIMIT ;
SELECT prod_name ,prod_price FROM products WHERE prod_price = 2.50;
SELECT prod_name ,prod_price FROM products WHERE prod_name = 'fuses';
SELECT prod_name,prod_price FROM products WHERE prod_price <;
SELECT vend_id , prod_name FROM products WHERE vend_id <> ;
SELECT prod_name , prod_price FROM products WHERE prod_price BETWEEN AND ;
SELECT prod_id , prod_price ,prod_name FROM products WHERE vend_id = AND prod_price <=;
SELECT prod_id , prod_price ,prod_name FROM products WHERE vend_id = OR vend_id = ;
SELECT prod_name , prod_price FROM products WHERE vend_id = OR vend_id = AND prod_price >=;
SELECT prod_name , prod_price FROM products WHERE (vend_id = OR vend_id = ) AND prod_price >=;
SELECT prod_name , prod_price FROM products WHERE vend_id IN (,) ORDER BY prod_name;
SELECT prod_name , prod_price FROM products WHERE vend_id= OR vend_id= ORDER BY prod_name;
SELECT prod_name , prod_price FROM products WHERE vend_id NOT IN (,) ORDER BY prod_name;
mysql-3 检索数据(1)的更多相关文章
- Mysql必知必会 检索数据
检索数据 SELECT 语句 为了使用SELECT检索表数据,必须至少给出两条信息--想选择什么,以及从什么地方选择 功能 语句 备注 检索单个列 SELECT col_1 FROM table_na ...
- MySQL 检索数据(SELECT)
检索单个列 mysql> SELECT 列名 FROM 表名; 如下,从表products中检索prod_name列 mysql> SELECT prod_name FROM ...
- MySQL 检索数据及提高检索速度的方法
检索数据 mysql> SELECT [DISTINCT] 表名.列名,表名.列名,表名.列名 -- 使用通配符*表示所有列 DISTINCT表示返回不同的值 -> FROM 数据库名.表 ...
- MySQL必知必会 读书笔记三:检索数据和数据排序
检索数据 SELECT语句 它的用途是从一个或多个表中检索信息. 为了使用SELECT检索表数据,必须至少给出两条信息--想选择什 么,以及从什么地方选择. 检索单个列 SELECT col_1 FR ...
- 《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)
<MySQL必知必会>检索数据,排序检索数据 1.检索数据 1.1 select 语句 为了使用SELECT检索表数据,必须至少给出两条信息一想选择什 么,以及从什么地方选择. 1.2 检 ...
- mysql必知必会(四、检索数据,五、排序检索数据,六、过滤数据,七、数据过滤)
四.select语句 1.检索单个列 select prod_name from products; 2.检索多个列 select prod_name, prod_price from product ...
- MySQL学习笔记(二)——检索数据与过滤数据
检索数据和过滤数据也就是平时用到最多的增删改查里面的查了. 一.数据检索 检索单个列: select column from table; 检索多个列: select colunm1,colu ...
- MySQL之对数据库库表的字符集的更改
数据字符集修改步骤: 对于已有的数据库想修改字符集不能直接通过 "alter database character set *"或 "alter table tablen ...
- Vusual C++连接Mysql和从MySql中取出数据的API介绍
.1 mysql_real_connect() 2.1.1 函数原型: MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const ...
随机推荐
- MySQL Workbench gnome-keyring-daemon错误的解决
在Fedora下安装了一个MySQL Workbench,运行,连接数据库,在Store in Keychain时出现了gnome-keyring-daemon错误,不能保存密码,也就连不上数据库. ...
- 数据查询语言DQL 与 内置函数(聚合函数)
数据查询语言DQL 从表中获取符合条件的数据 select select*from表的名字 查询表所有的数据.(select跟from必须一块用 成对出现的) * 表示所有字段,可以换成想要查询的 ...
- Java ConcurrentModificationException异常原因和解决方法
Java ConcurrentModificationException异常原因和解决方法 在前面一篇文章中提到,对Vector.ArrayList在迭代的时候如果同时对其进行修改就会抛出java.u ...
- MVC-自定义过滤器
APS.NET MVC中的每一个请求,都会分配给相应的控制器和对应的行为方法去处理,而在这些处理的前前后后如果想再加一些额外的逻辑处理.这时候就用到了过滤器. 自定义过滤器: 若要自定义一个过滤器,则 ...
- RSA加密解密(python版)
RSA的算法涉及三个参数,n.e.d. 其中,n是两个大质数p.q的积,n的二进制表示时所占用的位数,就是所谓的密钥长度. e1和d是一对相关的值,e可以任意取,但要求e与(p-1)*(q-1)互质: ...
- 利用Redis cache优化app查询速度实践
注意:本篇文章译自speeding up existing app with a redis cache,如需要转载请注明出处. 发现问题 在应用解决方法之前,我们需要对我们面对的问题有一个清晰的认识 ...
- Openfire重新安装
由于忘记密码等原因,无法启动openfire ,那就重装吧,废话不多说,命令行按步骤粘贴执行就好了. 1.先删除mysql数据 mysql -u root -p 输入密码:例如,123456 show ...
- Atom + activate-power-mode震屏插件Windows7下安装
Atom是Github推出的一个文本编辑器,搜索一下大概是给Web前端用的,最近比较火的是他的一个插件activate-power-mode,可以实现打字屏振效果. 用来装装逼还是挺适合的,本来想试试 ...
- Ansible用于网络设备管理 part 4 使用NAPALM成品库+Gabriele的方法+循环
上次用NAPALM实现了一个给端口加description的小功能,但是那次仅仅是用于给一个设备的一个端口加description,没有实现一次给多个设备加,也没有实现一个给多个端口加(虽然这次也没实 ...
- 推荐25款很棒的 HTML5 开发框架和开发工具【上篇】
HTML5 在不同的领域让网页设计更强大的.快速,安全,响应式,互动和美丽,这些优点吸引更多的 Web 开发人员使用 HTML5.HTML5 有许多新的特性功能,允许开发人员和设计师创建应用程序和网站 ...