数据库,单表查询,多表查询,子查询

数据库,单表查询,多表查询,子查询,第1张

注意点

select 指定表字段 from 表1,表2

四则运算包括加减乘除

select 字段1 四则运行符号 字段2 from 表名称

语法:select 函数(字段1) from 表名称

统计函数

binary

区分大小写

语法:select 段落 from 表明 where binary 字段

分组

语法

selectfrom 表名

where

group by 字段名称 #如果这里有多个字段,A,B,用,连接表示具有相同字段A以及相同字段B进行分组

having 判断内容

注意 :

排序

语法:默认为升序

ord by 字段名称

固定升序或者降序

多个条件排序主次关系

ord by 主字段,次字段

限制显示记录

对于单页表 *** 作

limit start count

对于多页 *** 作

分页原理:先查询总数据条数 设为a

确定每页数量b

总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4

查询语句的起始位置为s = 当前页数d 减去1 乘以每页数量

即 s = (d - 1) b

limit s b

语法 :where 字段名称 regexp '正则表达式'

注意:正则表达式不包括特殊字符如\w

语法:select from 表1,表2

他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接

其本质就是笛卡尔积查询

区别是把,变成 join

且不能用where,要先用on根据里面值的关系拼接好了再用 where

左表中记录的无论是否有匹配关系都全部显示,右表中仅显示匹配成功的记录

语法:select from 表1 left join,表2

右表中记录的无论是否有匹配关系都全部显示,左表中仅显示匹配成功的记录

语法:select from 表1 right join 表2

无论是否匹配成功,两边表中的记录都要全部显示

select from 表1 full join 表2

注意:mysql 不支持

我们要引入union

union 只能用于字段数量相同的两个表 会自动去除重复的记录

union all 则保留所有记录

select from dept left join emp on deptid=empdept_id

union

select from dept right join emp on deptid=empdept_id;

可以完成全外连接

在三表以及三表以上查询的时候,表1 join 表2 join 表三,其意思是表1与表2连接后的表再与表3进行连接

如果三表连接时候没有用join而是用 , 进行连接表示同时查询3个表

将查找后的内容作为查找的值或者查找的对象,

如果要作为一个表当作查找对象,要对于查找后的表进行重命名语法如下

select from (select from ) as 新名字

xists 后跟子查询 子查询有结果是为True 没有结果时为False

为true时外层执行 为false外层不执行

mysql试图中是不可以使用子查询的,你可以把子查询 建立成一个试图,代码如下:

CREATE  VIEW  View_bb  as ;

select id from bb;

然后再建立上面试图,调用该试图代码:

select a from aa a inner join  View_bb   b on aid=bid,这们就可以用子查询了。

MySQL 是一个关系型数据库,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。

MySQL 软件采用了双授权政策(本词条"授权政策"),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

由于其社区版的性能卓越,搭配 PHP ,Linux和 Apache 可组成良好的开发环境,经过多年的web技术发展,在业内被广泛使用的一种web服务器解决方案之一,称之为LAMP。

1返回一个值的子查询

2返回一组值的子查询

1返回一个值的子查询

(1)查询与刘伟职称相同的教师号、姓名和职称

(2)使用IN谓词查询讲授课程号为C1的教师姓名

(3)使用ALL谓词查询其他系中比计算机系所有教师工资都高的教师姓名、工资和所在系

(4)使用EXISTS谓词查询没有讲授C1课程的教师姓名、所在系

(5)使用NOT EXISTS谓词查询至少选修了学生S2选修的全部课程的学生学号

查询年龄不大于19岁或者是计算机系的学生

(1)查询年龄不大于19岁或者是计算机系的学生

不能先select出同一表中的某些值,再update这个表(在同一语句中)

解决方案

1

2

3

4

5

6

7

--1把需要删除的数据放到另外的一张表里

create table table_test as select oneName from one

group by OneName,OneAge,oneSex,oneAddress having count(oneName) > 1;

--2删除不需要的数据

delete from one where onename in(select oneName from table_test);

--3删除创建的表

drop table table_test;

以上就是关于数据库,单表查询,多表查询,子查询全部的内容,包括:数据库,单表查询,多表查询,子查询、mysql建视图的时候不能用子查询,mysql我用的是5.5版的了,怎么办、数据库数据查询之嵌套查询与集合查询等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存