SELECT 语句的简化语法如下:

SELECT  what to retrive
FROM table or tables
WHERE conditions that data must satisfy;

1.在写SELECT语句的时候,需要先指定检索的内容,然后再加上一些可选的子句。

(i)  FROM 子句通常是不可少的,但当不需要给出表名时,可以省略它。例如,下面这条查询语句只显示一些表达式的值。这些值计算并未涉及任何表,因此这里不需要FROM子句:

mysql> SELECT +,'Hello, World!',VERSION(),USER();
+-----+---------------+-----------+----------------+
| + | Hello, World! | VERSION() | USER() |
+-----+---------------+-----------+----------------+
| | Hello, World! | 5.6. | root@localhost |
+-----+---------------+-----------+----------------+
row in set (0.00 sec)

(ii) 当的确需要FROM子句来指定要从哪个表检索数据时,还需要指明要查看哪些列。

SELECT语句最常见的一种形式是使用一个星号(*) 作为列说明符,代表"所有列"。下面这条查询语句将显示 student 表里的所有列:

mysql> SELECT * FROM student;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Jim | M | |
| Tom | M | |
| Lily | F | |
| Lucy | F | |
| Travis | M | |
| Steve | M | |
+--------+-----+------------+
rows in set (0.00 sec)

(iii)也可以把自己想要查看的那些列的名字列出来。例如,只想查看学生名字,则可以这样做:

mysql> SELECT name FROM student;
+--------+
| name |
+--------+
| Jim |
| Tom |
| Lily |
| Lucy |
| Travis |
| Steve |
+--------+
rows in set (0.00 sec)

(iv) 要列出多个列名,那么需要使用逗号把它们分隔开。下面这条语句等价于 SELECT * FROM student 语句,但它把各列的名字明确地列了出来:

mysql> SELECT name,sex,student_id FROM student;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Jim | M | |
| Tom | M | |
| Lily | F | |
| Lucy | F | |
| Travis | M | |
| Steve | M | |
+--------+-----+------------+
rows in set (0.00 sec)

也可以按照任意顺序列出列名:

mysql> SELECT sex,student_id,name FROM student;
+-----+------------+--------+
| sex | student_id | name |
+-----+------------+--------+
| M | | Jim |
| M | | Tom |
| F | | Lily |
| F | | Lucy |
| M | | Travis |
| M | | Steve |
+-----+------------+--------+
rows in set (0.00 sec)

2. 指定检索条件

(i) 要想限制SELECT语句检索出来的行数,可以使用WHERE 子句,指定列值所必须满足的检索条件。例如,可以搜索某个范围内的数值:

mysql> SELECT * FROM student WHERE student_id > ;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Lucy | F | |
| Travis | M | |
| Steve | M | |
+--------+-----+------------+
rows in set (0.00 sec)

(ii)可以查找包含字符数据的字符串值。对于默认的字符集和排序方式,字符串的比较操作通常不区分大小写:

mysql> SELECT * FROM student WHERE sex='M';
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Jim | M | |
| Tom | M | |
| Travis | M | |
| Steve | M | |
+--------+-----+------------+
rows in set (0.00 sec)

(iii) 还可以查找组合值

mysql> SELECT * FROM student WHERE sex='M' OR student_id > ;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Jim | M | |
| Tom | M | |
| Lucy | F | |
| Travis | M | |
| Steve | M | |
+--------+-----+------------+
rows in set (0.00 sec)

  WHERE 子句里的表达式允许使用算术运算符、比较运算符和逻辑运算符。在表达式里还可以使用括号。在运算时,可以使用常量、表列和函数调用。

常用运算符如下:

算术运算符
运算符 含义
+ 加法
- 减法
* 乘法
/ 除法
DIV 整除
% 模运算(除法余数)
比较运算符
< 小于
<= 小于等于(不大于)
= 等于
<=> 等于(可用于NULL值)
<>或!= 不等于
>= 大于等于(不小于)
> 大于
   
逻辑运算符
AND 逻辑与
OR 逻辑或
XOR 逻辑异或
NOT 逻辑非

(iv)使用 IN() 运算符

下面这两条语句效果等价:

mysql> SELECT * FROM student WHERE student_id= or student_id=;
+------+-----+------------+
| name | sex | student_id |
+------+-----+------------+
| Lily | F | |
| Lucy | F | |
+------+-----+------------+
rows in set (0.00 sec) mysql> SELECT * FROM student WHERE student_id IN(,);
+------+-----+------------+
| name | sex | student_id |
+------+-----+------------+
| Lily | F | |
| Lucy | F | |
+------+-----+------------+
rows in set (0.00 sec)

(v) NUL值

  NULL值很特殊。其含义是“无值”或“未知值”,所以不能采用两个“已知值”的比较方式,将它与“已知值”进行比较。如果试图将NULL与常规的算术比较运算符一起使用,那么其结果将是未定的(undefined):

mysql> SELECT NULL<,NULL=,NULL<> ,NULL> ;
+--------+--------+----------+---------+
| NULL< | NULL= | NULL<> | NULL> |
+--------+--------+----------+---------+
| NULL | NULL | NULL | NULL |
+--------+--------+----------+---------+
row in set (0.01 sec)

  事实上,也不能让NULL与其自身进行比较,因为两个“未知值”的比较结果是无法确定的:

mysql> SELECT NULL=NULL,NULL<>NULL;
+-----------+------------+
| NULL=NULL | NULL<>NULL |
+-----------+------------+
| NULL | NULL |
+-----------+------------+
row in set (0.00 sec)

  如果需要测试某个值和NULL值是否相等,那么必须使用 IS NULL 或 IS NOT NULL,而不能使用 = , <> 或者 !=。

  MySQL特有的 <=> 比较运算符可以用于 NULL 值与 NULL 值的比较:

mysql> SELECT NULL <=> NULL;
+---------------+
| NULL <=> NULL |
+---------------+
| |
+---------------+
row in set (0.00 sec)

3. 对查询结果进行排序

(i)使用 ORDER BY 子句进行排序:

mysql> SELECT * FROM student ORDER BY name;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Jim | M | |
| Lily | F | |
| Lucy | F | |
| Steve | M | |
| Tom | M | |
| Travis | M | |
+--------+-----+------------+

(ii) ORDER BY 子句的排序方式是升序排列。在其中的列名后面加上关键字 ASC 或 DESC,可以指定是按照升序排列还是按照降序排列。如:

mysql> SELECT * FROM student ORDER BY name DESC;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Travis | M | |
| Tom | M | |
| Steve | M | |
| Lucy | F | |
| Lily | F | |
| Jim | M | |
+--------+-----+------------+

(iii) 可以对多列进行排列,而且每一列单独地按升序或降序排列:

mysql> SELECT * FROM student ORDER BY name DESC, student_id ASC;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Travis | M | |
| Tom | M | |
| Steve | M | |
| Lucy | F | |
| Lily | F | |
| Jim | M | |
+--------+-----+------------+

4.限制查询结果

LIMIT n 子句限制输出的行数:

mysql> SELECT * FROM student ORDER BY name ASC LIMIT ;
+------+-----+------------+
| name | sex | student_id |
+------+-----+------------+
| Jim | M | |
| Lily | F | |
| Lucy | F | |
+------+-----+------------+

LIMIT还允许从查询结果的中间抽出部分行。此时需要指定两个值:第一个,给出从查询结果的开头部分跳过的行数目;第二个,需要返回的行数目:

mysql> SELECT * FROM student LIMIT ,;
+--------+-----+------------+
| name | sex | student_id |
+--------+-----+------------+
| Lucy | F | |
| Travis | M | |
+--------+-----+------------+

如果想从某个表里随机抽取一行或几行,那么可以联合使用 LIMIT 子句和 ORDER BY RAND() 子句:

mysql> SELECT * FROM student ORDER BY RAND() LIMIT ;
+------+-----+------------+
| name | sex | student_id |
+------+-----+------------+
| Lucy | F | |
+------+-----+------------+
row in set (0.00 sec) mysql> SELECT * FROM student ORDER BY RAND() LIMIT ;
+------+-----+------------+
| name | sex | student_id |
+------+-----+------------+
| Tom | M | |
+------+-----+------------+
row in set (0.00 sec)

可以看到两次查询结果不同,这体现了随机性。

MySQL数据库(2)----检索信息的更多相关文章

  1. 将从mysql数据库查询的信息,遍历到List<>以及一些随机数的生成

    将从mysql数据库查询的信息,遍历到List<>以及一些随机数的生成. 代码比较乱,但是方法还是对的,大家又需要的选择看,希望对博友 有帮助,欢迎留言分享! public class s ...

  2. 案例分享:Qt西门子机床人机界面以及数据看板定制(西门子通讯,mysql数据库,生产信息,参数信息,信息化看板,权限控制,播放器,二维图表,参数调试界面)

    若该文为原创文章,转载请注明原文出处本文章博客地址:https://blog.csdn.net/qq21497936/article/details/118685521 长期持续带来更多项目与技术分享 ...

  3. 查询mysql数据库表的信息(表大小、数据大小、索引大小)

    select * from information_schema.TABLES where information_schema.TABLES.TABLE_SCHEMA='databasename' ...

  4. 查看连接MYSQL数据库的IP信息

    要统计数据库的连接数,我们通常情况下是统计总数,细分到每个ip地址: 方法一: ) as ip , count(*) from information_schema.processlist group ...

  5. CentOS6.8下MySQL数据库版本信息查看

    方法1:使用mysql -v命令查看: [root@yeebian mysql]# mysql -V mysql Ver 14.14 Distrib 5.1.73, for redhat-linux- ...

  6. MySql数据库与JDBC编程

    JDBC -- Java Database Connectivity,即Java数据库连接,通过使用JDBC就可以使用同一种API访问不同的数据库 SQL语句基础(SQL结构化查询语言) 能完成的任务 ...

  7. MySQL数据库和InnoDB存储引擎文件

    参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...

  8. 查看mysql数据库版本方法总结

    当你接手某个mysql数据库管理时,首先你需要查看维护的mysql数据库版本:当开发人员问你mysql数据库版本时,而恰好你又遗忘了,那么此时也需要去查看mysql数据库的版本............ ...

  9. 三种方法查看MySQL数据库的版本

    1.使用-V参数 首先我们想到的肯定就是查看版本号的参数命令,参数为-V(大写字母)或者--version 使用方法: D:\xampp\mysql\bin>mysql -V 或者 D:\xam ...

随机推荐

  1. [原创]Heroku简单部署指南

    目录 1. 设置 1.1 环境依赖 1.2 Heroku 客户端安装 1.3 登录 2. 应用 2.1 创建 2.2 查看日志 2.3 附加组件 2.4 交互式 Shell 2.5 定义 配置变量 2 ...

  2. tomcat正常启动后http://localhost:8080/报错404

    病症: tomcat在eclipse里面能正常启动,而在浏览器中访问http://localhost:8080/不能访问,且报404错误.同时其他项目页面也不能访问.关闭eclipse里面的tomca ...

  3. BZOJ - 3295 三维偏序 空间转换

    题意:动态逆序对,共m次删除操作,求每次操作前的逆序对个数 删除操作转换为添加操作,首先对时间a进行简单排序 然后用cdq分治处理b维,树状数组处理c维 此时需要求的是对于某有序组\((a,b,c)\ ...

  4. How to Deinstall Oracle Clusterware Home Manually

    ###sample 0:安装GI 和DB soft 都成功,如何回退DB soft [opdb@pdbdb01:/db/db/app/db/product/11204/deinstall]$ ./de ...

  5. ngx_echo_module

    https://github.com/openresty/echo-nginx-module echo $echo_request_body

  6. SpringCloud---分布式配置中心---Spring Cloud Config

    1.概述 1.1 Spring Cloud Config是Spring Cloud的一个全新项目:   作用:为分布式系统中的基础设施.微服务应用提供集中化的外部配置支持:   分为服务端.客户端2个 ...

  7. 加载 Firefox 配置

    有小伙伴在用脚本启动浏览器时候发现原来下载的插件不见了,无法用 firebug在打开的页面上继续定位页面元素,调试起来不方便 .加载浏览器配置,需要用 FirefoxProfile(profile_d ...

  8. 关于DeferredResult的思考

    使用SpringBoot搭建web程序,里面内置了tomcat,一般都不会关心内部实现机制,上来就可以写程序,并且可以跑起来.但是是思考了每次的请求是如何工作的. 简单的来讲就是tomcat是将每次请 ...

  9. FZU 2138——久违的月赛之一——————【贪心】

    久违的月赛之一 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Stat ...

  10. 开发常用的 JavaScript 知识点总结

    No1.语法和类型 1.声明定义 变量类型:var,定义变量:let,定义块域(scope)本地变量:const,定义只读常量.变量格式:以字母.下划线“_”或者$符号开头,大小写敏感.变量赋值:声明 ...