数据库中select的用法

数据库中select的用法,第1张

数据库中select的用法的用法你知道吗?下面我就跟你们详细介绍下数据库中select的用法的用法,希望对你们有用。

数据库中select的用法的用法如下:

1、select语句可以用回车分隔

?

1

2

3

4

$sql="select * from article where id=1"

$sql="select * from article

where id=1",都可以得到正确的结果,但有时分开写或许能更明了一点,特别是当sql语句比较长时

2、批量查询数据

?

1

2

可以用in来实现

$sql="select * from article where id in(1,3,5)"

3、使用concat连接查询的结果

?

1

$sql="select concat(id,"-",con) as res from article where id=1"

返回"1-article content"

4、使用locate

用法:

select locate("hello","hello baby")返回1

不存在返回0

5、使用group by

以前一直没怎么搞明group by 和 order by,其实也满简单的,group by 是把相同的结果编为一组

?

1

exam:$sql="select city ,count(*) from customer group by city"

这句话的意思就是从customer表里列出所有不重复的城市,及其数量(有点类似distinct)

group by 经常与AVG(),MIN(),MAX(),SUM(),COUNT()一起使用

6、使用having

having 允许有条件地聚合数据为组

?

1

2

$sql="select city,count(*),min(birth_day) from customer

group by city having count(*)>10"

这句话是先按city归组,然后找出city地数量大于10的城市

btw:使用group by + having 速度有点慢

同时having子句包含的表达式必须在之前出现过

7、组合子句

where、group by、having、order by(如果这四个都要使用的话,一般按这个顺序排列)

8、使用distinct

distinct是去掉重复值用的

?

1

$sql="select distinct city from customer order by id desc"

这句话的意思就是从customer表中查询所有的不重复的city

9、使用limit

如果要显示某条记录之后的所有记录

?

1

$sql="select * from article limit 100,-1"

10、多表查询

?

1

2

3

4

$sql="select user_name from user u,member m

where u.id=m.id and

m.reg_date>=2006-12-28

order by u.id desc"

作用就是从数据库中检索数据,并将查询结果返回给用户。

Select语句由select子句(查询内容)、from子句(查询对象)、where子旬(查询条件)、order by子句(排序方式)、group by子句(分组方式)等组成。

计算列出在 FROM 中的所有元素。(FROM 中的每个元素都是一个真正的或者虚拟的表。)如果在 FROM 列表里声明了多过一个元素,那么他们就交叉连接在一起。

如果声明了 WHERE 子句,那么在输出中消除所有不满足条件的行。如果声明了 GROUP BY 子句,输出就分成匹配一个或多个数值的不同组里。如果出现了 HAVING 子句,那么它消除那些不满足给出条件的组。

扩展资料:

DISTINCT 从结果中删除那些重复的行。DISTINCT ON 删除那些匹配所有指定表达式的行。ALL (缺省)将返回所有候选行,包括重复的。

如果给出了 LIMIT 或者 OFFSET 子句,那么 SELECT 语句只返回结果行的一个子集。

如果声明了 FOR UPDATE 或者 FOR SHARE 子句, SELECT 语句对并发的更新锁住选定的行。

你必须有 SELECT 权限用来从表中读取数值。使用 FOR UPDATE FOR SHARE 还要求 UPDATE 权限。

select [要查询的字段] from [表名]

where [指定的查询条件]

有记得需要说明的是,如果存在多个条件时需要用and 连接每个查询条件,如果需要排序,语法则为:

select [要查询的字段] from [表名]

where [指定的查询条件]

order by [要分组的字段]


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10701299.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存