包含mysqlselect语句的词条

语宇社区 经典句子 78 0

mysql中的select语句where条件group by ,having , order by,limit的顺序及用法

语句顺序

select 选择的列

from 表

where 查询的条件

group by 分组属性 having 分组过滤的条件

order by 排序属性

limit 起始记录位置,取记录的条数

其中

select 选择的列

from 表

where 查询的条祥模件

以上是基本的结构

group by 分组属性 having 分组过滤的基答条件

这个是按照分组属性进行分组,所有分组属性上值相同的记录被分为一组,作为结果中的一条记录,后面的having是对分组进行过滤的条件,必须和group by一起使谨锋缓用

order by 排序属性 是对结果集合进行排序,可以是升序asc,也可以是降序desc

limit 起始记录位置,取记录的条数

对记录进行选取,主要用来实现分页功能

MySQL笔记1select基础

查询语句:select 语句

三种能力:投影、选择、连接

投影:在一张二维表中根据所需要的条件选出所需要的列

选择:在二维表中根据所需的条件选择合适的行

连接:从一张或者多张表中获取所需要的行,并且把这个行结合在一起的查询

SQL语句大小写不敏感。

select语句是可以计算的

算术表达式和判启运算符优先级

举例:select ename,sal 12*sal+100 from emp

计算出年薪+100块

NULL值是不可用,且未分配的,未知并且不适用的值,可以当成是保留值

AS其实可以省略

例如:select ename as name,sal salary from emp;

查询出的字段会自动换成别名

例子:select ename "Name",sal*12 "Annual Salary" from emp;

级联操作是将列或字符串和其他列串联,由两条竖线(||)表示

select ename,job,ename || job as "Employees" from emp;

可以看出Employees就将ENAME和JOB进行结合的一个操作

在select句子中适用DISTINCT 关键字消除重复行

select distinct deptnp from emp;

限制选择的行:

where关键字

如果where后面查的数据是字符串类型或者日期类型的要加''号

#######比较条件

举几个例子:

select ename,job,sal,deptno from emp where sal between 5000 and 10000;

这个是包含了5000和10000的

in的表达:

select empno,ename,mgr,deptno from emp where mgr in (7788,7782,7000);

只要mgr有括号里面的值都显示出来。

通配符:%通配的是多个字符,_通配的是一个字符

IS NULL是查询某个字段为空的显示出来

and、or、not

例子:

查如冲团询sal=2000和job的内容是包括MAN字符串的,当同时满足两个条件时候才返回结果。

and就是两边同时为真,or的话是有一边为真就行,not就是不等于

ASC 升序,默认升序

DESC 降序

例子:

将deptno中进行升序渣橘排列,排列出来后,在将sal进行降序排列。

单行函数:就是对单行数据进行处理的函数,只针对这一条数据得出一个结果

函数工作的过程

ROUND(45.926,2)是将45.926这个数字的小数点后两位进行四舍五入操作得到45.93

TRUNC(45.926,2) 是将45.926这个数字的小数点后两位后面的进行丢掉。

返回当前系统日期

经常是不同类型之间的转换

TO_CHAR就是将日期型数字型转换成字符型

例子:

数字型的转换

把字符转换成数字:

把字符转换成日期:

什么是分组函数?

另外的名字叫多行函数,针对于多行数据进行一个汇总处理的一类函数,最后会得到一个汇总的结果。

例子:

其实就是对一系列数据找最大值

基本格式:select group_function(column),... from table [where condition];

首先对一个数据进行分类汇总把每一组的数据单独的拿出来。就是对每一列数据的相同数据进行一个分组,然后在将分组后的结果再去执行select后面跟的一个分组函数的操作。

例子:

那下面这样的怎么操作呢?

其实就是对分组以后的结果再次进行一个限制筛选

where和Having的区别?

where是针对于整体的一个查询结果

Having是针对于分组后的查询结果的一个条件限制,它是不能单独存在的,它只能够在group by后面

下面是它的表达式:

显示部门的最大平均薪水是多少

select max(avg(sal))

是这样的一个嵌套

当我们查的数据存在于多个表的时候就需要多表查询

下面是用到的表

一个是EMP的职员表、一个是DEPT的部分表

表连接的三种方式:

从总类上来看:自连接、等值连接、外连接(又可以分为三类:左连接、右连接、全连接)

自连接:一个表自己与自己建立连接成为自连接或自身连接。

在查询的时候多表,这两张表是同一张表,所以在查询前我们需要对这个表进行一个别名的重命名。

举例:查询出员工编号、名字及其经理名字

MGR对应的是经理的ID号,这个对应的就是另一张经理表中的名字

表示比较连接列的值显示出最终的一个结果,其查询结果中列出被连接表中的所有列,包括其中的重复列。

查询员工的姓名 工作 部门号 部门名称

左连接就是返回左边的匹配行,不考虑右边的表是否有相应的行

(+)的意思就是dept是个匹配表,左边是一个基础表,基础表优先,如果右边这个表找不到对应的值去匹配,会自动填空

右连接就是返回右边的匹配行,不考虑左边的表是否有相应的行,如果没有会自动填空

左表右表都不做限制,所有的记录都显示,不足的地方用null填充

FULL JOIN表示emp和dept做一个全连接

ON表示触发条件 。

MySQL中select语句使用order按行排序

本文介绍MySQL数据库中执行select查询语句,并对查询的结果使用order

by

子句进行排序。

再来回顾一下SQL语句中的select语句的语法:

Select

语句的基本语法:

Select

列的集合

from

表名

where

条件

order

by

排序字段和方式

如果要对查询结果笑态戚按某个字段排序,则要使用order

by

子句闭宴,如下:

select

*

from

表名

order

by

字段名称

排序方式

下面来看两个例子,第一个查询test表中所有数据,并按t_id正序排列;第二个查询与第一个相反,是逆序排碰陵列。

mysql

select

t_id,t_name

from

test

order

by

t_id;

+------+--------+

|

t_id

|

t_name

|

+------+--------+

|

1

|

name1

|

|

2

|

name2

|

+------+--------+

2

rows

in

set

(0.00

sec)

mysql

select

t_id,t_name

from

test

order

by

t_id

desc;

+------+--------+

|

t_id

|

t_name

|

+------+--------+

|

2

|

name2

|

|

1

|

name1

|

+------+--------+

2

rows

in

set

(0.00

sec)

注意:正序排序时,可以使用asc作为排序方式的关键词,也可以不使用。逆序时,一定要使用desc作为关键词。

关于MySQL中select语句使用order按行排序,本文就介绍这么多,希望对大家有所帮助,谢谢!

快速掌握MySQL数据库中SELECT语句[2]

where子句设置了搜索条件 它在insert update delete语句中的应用方法也与在select语句中的应用方法完全相同 搜索条件紧跟在关键词where的后面 如果用户要在语句中使用多个搜索条件 则可用and或or连接 搜索条件的基本语法是[not] expression parison_operator expression;[not] expression [not] like match_string ;[not] expression is [not] null;[not] expression [not] beeen expression and expression;[not] column_name join_operator column_name;[not] boolean_expression

and 用来联结两个条件 并在两个条件都是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 and运算符总是最优先 除非用户用括号改变了运算顺序

or 用来联结两个条件 当两个条件中有任一条件是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 运算符or通常在运算符and之后进行运算 当然用户可以使用括号改变运算的顺序

beeen 用来标识范围下限的关键词 and后面跟范围上限的值 范围where @val beeen x and y包含孝悄者首尾值 如果beeen后面指定的第一个值大于第二个值 则该查询不返回任何行

column_name 在比较中使用的列名 在会产生歧义时 一定要指明列所在的表名

parison_operator 比较运算符 见下表

Word WRAP: break word bgColor=#f f f 以下是引用片段 符号   意义 =      等于       大于       小于 =     大于等于 =     小于等于 !=     不等于      不等于

在比较char varchar型 数据 时 的意思是更接近字母表头部 代表更接近字母表尾部 一般来说 小写字母大于大写字母 大写字母大于数字 但是这可能依赖于 服务器 上 操作系统 的比较顺序

在比较时 末尾的空格是被忽略的 例如 Dirk 等于 Dirk

在比较日期时 表示早于 表示晚于

在使用比较运算符比较character和datetime数据时 需用引号将所有数据引起来

expression 可能是列名 常数 函数或者是列名或常数的任意组合 以及以算术运算符或逐位运算符连接的函数 算术运算符如下表所示

以下是引用片段 符号   意义 +      加号       减号    *      乘号 /      除号

is null 在搜索一个NULL值时使用

like 关键词 对char varchar和datetime(不包括秒和毫秒)可以使用like 在 MySQL 中like也可以用在数字的表达式上

当用户在搜索datetime型 数据 时 最好是使用关键词like 因为完整的datetime记录包含各种各样的日期组件 例如用户在列arrival_time中加入一个值 : 而子句where arrival_time= : 却没有发现它 因为MySQL把录入的数据转换成了 Jan : AM 然而子句where arrival_time like % : % 就能找到它

运拦boolean_expression 返回 true 或 false 值的表达式

match_string 由字符和通配符组成的串 用单引号或双引号引起来 是匹配模式 通配符如下表所示

Word WRAP: break word bgColor=#f f f 以下是引用片段 符号       意义 %          或多个字符的字符串 _           任何一单个巧薯字符 not      否定任何逻辑表达式 或是关键词              如like null beeen等 group    by和having子句在select语句中使用               可以将表划分成组并返回匹配having子句条件的组 语法 select语句开头 group by [all] aggregate_free_expression [ aggregate_free_expression]* [having search_conditions]

select语句结尾

group by 指定表将划分的组群 如果在select表项中包含集合函数 则为各组计算一个总计值 这些总计值的结果以新的列显示 而不是新的行 在having子句中用户可以引用这些新的总计列 在group by之前的select_list中可以使用avg count max min和sum等集合函数 表可以被任意列的组合分组

all 在结果中包含所有组群的Transact SQL扩展 这里的所有组群甚至包括那些被where子句所排除的组群 如果同时使用having子句 将对all的意义进行否定

aggregate_free_expression 不包含集合函数的表达式 Transact SQL扩展允许在用列名称分组的同时 用无集合函数的表达式分组

having 为group by子句设置条件 类似于where为select语句设置条件的方法 having的查找条件可以包括集合函数表达式 除此之外 它的查找条件与where查找条件相同

order by 按列排列结果 对select输出的列可以用列名 列别名或列位置来引用 例如 select id as myid name as myname from mytable group by id select id as myid name as myname from mytable group by myid select id as myid name as myname from mytable group by 这三句是完全等价的 当然 我们不赞成用第三种用法 这将给程序的可读性带来不好的影响 为了以降序排列 把DESC关键词加到order by子句中你要排序的列名前 缺省是升序 你也可以用ASC关键词明确指定

limit 子句 用来限制select语句返回的行数 limit取 个或 个数字参数 如果给定 个参数 第一个指定要返回的第一行的偏移量 第二个指定返回行的最大数目 初始行的偏移量是 (不是 ) 如果给定一个参数 它指出偏移量为 的返回行的最大数目 也就是说limit 和limit 完全等价

至于procedure关键词的含义 我也没搞得太清楚 好象是对存储过程的支持 而MySQL本身不支持存储过程 看来是为了将来扩充的需要而保留的吧

lishixinzhi/Article/program/MySQL/201311/29617

MySQL使用select语句查询指定表中指定列(字段)的数据

本文介绍MySQL数据库中执行select查询语句,查询指定列的数据,即指定字段的数据。

再来回顾一下SQL语句中的select语句的语法:

Select

语句的基闭宴本语法:

Select

列的笑态戚集合

from

表名

where

条件

order

by

排序字段和方式

如果要查询某个表中的指定列的所有数据,则查询语句可以写作:

select

列名1,列名2,列名3...

from

表名

要说明一个,这个语句后面仍然可以碰陵使用where子句,用来选择指定行的指定列。这样可以更精准的查询出需要的结果来。

下面来看一个例子,查询test表中,t_name和t_birth两个字段的数据,并且匹配行t_name='name2':

mysql

select

t_name,t_birth

from

test

where

t_name='name2';

+-------+------------+

|

t_name

|

t_birth

|

+-------+------------+

|

name2

|

2013-01-01

|

+-------+------------+

1

rows

in

set

(0.00

sec)

关于MySQL使用select语句查询指定表中指定列(字段)的数据,本文就介绍这么多,希望对大家有所帮助,谢谢!

mysql如何在select语句中对time类型的值进行比较?

SELECT * FROM table WHERE time_to_sec(time)time_to_sec('15:00:00'稿晌)

以上为比较方法。

在Oracle系统中,select语句的基本语法格式如下:

select [distinct] [*, column_name [alias], …] from tablename Where {conditions} group by {conditions} having order by expressions} [ASC/DESC];

查询所有列:

select * from table;

查询袜敬轿指定列:select colum1,colum2 from table;

取消重复行:select distinct deptno,job from emp;

使用表达式:可以告肆在查询列中使用表达式来连接字符串(使用 || 连接字符串)、改变显示格式(如使用函数to_char)、计算显示的数据(如使用+,-,×,/)等。

举例:

select * from emp;

select ename ,sal,deptno from emp;

select deptno from emp;

select distinct deptno from emp;

发布评论 0条评论)

  • Refresh code

还木有评论哦,快来抢沙发吧~