一、查询加强

1、在mysql中,日期类型可以直接比较,需要注意格式

2、%:表示0到多个字符,

_:表示单个字符

exp:显示第二个字符为大写O的所有员工的姓名和工资

select  name from table

    where name like '_O%';

3、查询某个字符字段为空

4、查询表结构:DESC table(table表示表名)

例:DESC user

二,分页查询

1、基本语法:

数据分组总结:

如果select语句同时包含有group by ,having , limit、order by那么他们的

顺序是group by , having , order by,limit

三、多表查询:多表查询是指基于两个表或多个表的查询

tips:多表查询条件不能少于表的个数-1,否则会出现笛卡尔集

在默认情况下,多表查询时,规则

1,从第一张表中,取出一行和第二张表的每一行进行组合,返回结果【含有两张表的所有列】

2、一共返回的记录数,第一张表行数*第二张表的行数

3、这样多表查询默认处理返回结果,称为笛卡尔集

4、解决这个多表的关键就是要写出正确的过滤条件where

多表查询的自连接:

特点:

1、把同一张表当做两张表使用

2、需要给表取别名,表名   表别名

3、列名不明确,可以指定列的别名

例:

四、mysql表的子查询:子查询是指嵌套在其它SQL语句中的select语句,也叫嵌套语句

单行子查询:单行子查询是指只返回一行数据的子查询语句

多行子查询:多行子查询指返回多行数据的子查询使用关键字in

将子查询当做临时表使用;

all和any的使用:

单列子查询all表示那个子查询中的所有

any表示子查询中的任意一个

多列子查询:查询返回多个列数据的子查询语句

(.*):table.*--->表示table表中的所有列

表复制:自我复制数据(蠕虫复制):为了对某个sql语句进行效率测试,我们需要海量数据时,可以使用此法为表创建海量数据;

考虑去重 my_tab02的记录
/*
思路
(1) 先创建一张临时表 my_tmp , 该表的结构和 my_tab02一样
(2) 把my_tmp 的记录 通过 distinct 关键字 处理后 把记录复制到 my_tmp
(3) 清除掉 my_tab02 记录
(4) 把 my_tmp 表的记录复制到 my_tab02
(5) drop 掉 临时表my_tmp
*/
-- (1) 先创建一张临时表 my_tmp , 该表的结构和 my_tab02一样

create table my_tmp like my_tab02
-- (2) 把my_tmp 的记录 通过 distinct 关键字 处理后 把记录复制到 my_tmp
insert into my_tmp
select distinct * from my_tab02;

-- (3) 清除掉 my_tab02 记录
delete from my_tab02;
-- (4) 把 my_tmp 表的记录复制到 my_tab02
insert into my_tab02
select * from my_tmp;
-- (5) drop 掉 临时表my_tmp
drop table my_tmp;

五。合并查询(为了合并多个select语句的结果,可以使用集合操作符号union,

union all)进行合并

1、union all 就是将两个查询结果合并,不会去重

2、union的操作与union all 相似,但是会自动去掉结果中重复行

六、mysql表外连接

1、左外连接 :select  .. from 表1 left join 表2 on 条件;【表1就是左表】

如果有字段不匹配,就会显示空

2、右外连接

七、mysql约束

基本介绍:约束用于确保数据库的数据满足特定的商业规则。在mysql中,约束包括:

not null、unique,primary key,foreign key,和check五种.

1、主键的使用:primary key:

细节:

1)primary key 不能重复,而且不能为null。

2)一张表最多只能有一个主键,但可以是复合主键

在表中添加:primary key(字段一,字段二);(其中字段一和字段二就是一个复合主键)只有当字段一二完全相同是才违反主键定义

主键的指定方式:

1)直接在字段名后指定:字段名 primary key

2)在表定义最后写primary key(列名)

3)使用desc表名,可以看到primary key的情况

2、not null(非空):如果在列定义了not null,那么当插入数据时,必须为列提供数据。

3、unique(唯一):当定义了唯一约束后,该列值是不能重复的。

unique细节:

1).如果没有指定not null,则unique字段可以有多个null

2).一张表可以有多个unique字段

3)、如果一个列(字段),是unique not null使用效果类似primary key;

4、foreign key(外键)

用于定义主表和从表之间的关系:外键约束要定义在从表上,主表则必须具有主键约束或是unique约束.当定义外键约束后,要求外键列数据必须在主表的主键列存在或是为null

外键示意图:

外键创建语句:

foreign key(外键)--  细节说明

1).外键指向的表的字段,要求是primary key或者是
unique
2).表的类型是innodb,这样的表才支持外键
3).外键字段的类型要和主键字段的类型一致(长度可以不同)

4).外键字段的值,必须在主键字段中出现过,或者为null [前
提是外键字段允许为null]
5).一旦建立主外键的关系,数据不能随意删除了.

5、chack

用于强制行数据必须满足的条件,假定在sal列上定义了check约束并要求

sal列值在1000 ~2000之间如果不再1000 ~2000之间就会提示出错。工
oracle和sql server均支持check ,但是mysql5.7目前还不支持check,

只做语法校验,但不会生效。(在mysql中实现check的功能,一般是在程序中控制,或者通过触发器完成。)

 八、自增长

自增长细节:

1.一般来说自增长是和primary key配合使用的

2自增长也可以单独使用[但是需要配合一个unique]
3.自增长修饰的字段为整数型的(虽然小数也可以但是非常非常
少这样使用)
4.自增长默认从1开始,你也可以通过如下命令修改alter
table表名auto increment = XXX;

5、如果你添加数据时,给自增长字段(列)指定的有值,则以指定的值为准,如果指定了自增长,一般来说,就按照自增长的规则来添加数据

mysql表查询、多表查询(增强查询的使用)子查询、合并查询,外连接,mysql5种约束,自增长的更多相关文章

  1. MySQL笔记之多表

    貌似很久不写博客了,趁着项目刚完结,记录一下这段时间了解到的一些认识,或许有些地方理解的还不够到位,看到的希望能不吝赐教. 外键 概念 与索引的关系 写法 查询 一对多多对一查询 多对多查询 插入 多 ...

  2. Mysql常用sql语句(17)- left/right join 外连接

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 外连接分为两种:left join.right ...

  3. mysql外连接

    一,起因 在学习一个新知识之前,最好先了解一下你为何要学习这个知识,这个知识或技术能帮你做什么,可以给你带来哪些帮助.因此我先交代一下写这篇随笔的起因. 我在做项目的时候遇到了一个比较有意思的情况, ...

  4. mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化

    先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...

  5. MySQL学习笔记——多表连接和子查询

    多表连接查询 # 返回的是两张表的乘积 SELECT * FROM tb_emp,tb_dept SELECT COUNT(*) FROM tb_emp,tb_dept # 标准写法,每个数据库都能这 ...

  6. MySQL订单分库分表多维度查询

    转自:http://blog.itpub.net/29254281/viewspace-2086198/ MySQL订单分库分表多维度查询  MySQL分库分表,一般只能按照一个维度进行查询. 以订单 ...

  7. mysql中相关,无关子查询,表与表之间的关系以及编码和乱码的解决

    ※MySQL中的字符编码(注意,utf8中没有'-',跟Java中不一样)SHOW VARIABLES; //查看系统变量//查询字符编码相关的系统变量SHOW VARIABLES WHERE var ...

  8. MySQL查询数据表中数据记录(包括多表查询)

    MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...

  9. 4.mysql数据库创建,表中创建模具模板脚本,mysql_SQL99标准连接查询(恩,外部连接,全外连接,交叉连接)

     mysql数据库创建,表创建模等模板脚本 -- 用root用户登录系统,运行脚本 -- 创建数据库 create database mydb61 character set utf8 ; -- ...

随机推荐

  1. Hbase单点安装Version1.1.5

    Hbase单点安装,基于版本1.1.5, 使用hbase-1.1.5.tar.gz安装包. 1.安装说明 使用Hbase自带zookeeper和本地文件目录存储数据 2.安装规划 角色规划 IP/机器 ...

  2. Unity——ShaderLab实现玻璃和镜子效果

    在这一篇中会实现会介绍折射和反射,以及菲尼尔反射:并且实现镜子和玻璃效果: 这里和之前不同的地方在于取样的是一张CubeMap: demo里的cubemap使用的一样,相机所在位置拍出来的周围环境图: ...

  3. 前端必备,5大mock省时提效小tips,用了提前下班一小时

    ​ 一.一些为难前端的业务场景 在我的工作经历里,需要等待后端童鞋配合我的情形大概有以下几种: a.我们跟外部有项目合作,需要调用到第三方接口. 一般这种情况下,商务那边谈合同,走流程,等第三方审核, ...

  4. 发布 vscode 插件 Cnblogs Client For VSCode 预览版

    为了方便大家使用 vscode 发布博文,我们做了一个小插件,今天发布预览版,欢迎大家试用并反馈问题与建议. 插件的英文名称是 Cnblogs Client For VSCode,简称是 vscode ...

  5. CSS基础 结构伪类选择器 last-child、first-child和nth-of-type的使用方法

    一.通过伪类选择器查找单个标签元素html结构 <div> <a herf='#'>导航1</a> <a herf='#'>导航2</a> ...

  6. Sentry 企业级数据安全解决方案 - Relay 配置选项

    Relay 的配置记录在文件 .relay/config.yml 中.要更改此位置,请将 --config 选项传递给任何 Relay 命令: ❯ ./relay run --config /path ...

  7. python接口自动化,从excel取param的内容太多,使用eval转换报错'EOL while scanning string literal

    背景: 做接口自动化时,有个接口的参数内容很多,可以从excel中读取出来,但是在eval()进行转化时,就报错"'EOL while scanning string literal&quo ...

  8. IE8和IE9下textarea滚动选中的问题

    在IE8和IE9下如果textarea设置了样式overflow-y:auto;就不可以滚动选中了,应该样式写成overflow:auto;有了纵向滚动实际上就不会出现横向滚动的情况,也没有必要ove ...

  9. JVM调优工具锦囊

    Arthas线上 分析诊断调优工具 以前我们要排查线上问题,通常使用的是jdk自带的调优工具和命令.最常见的就是dump线上日志,然后下载到本地,导入到jvisualvm工具中.这样操作有诸多不变,现 ...

  10. HarmonyOS新能力让数据多端协同更便捷,数据跨端迁移更高效!

    作者:yijian,终端OS分布式文件系统专家:gongashi,终端OS分布式数据管理专家 HarmonyOS作为分布式操作系统,其分布式数据管理能力非常重要.我们也一直围绕持续为开发者带来全局&q ...