1.mysql查出数据表中连续出现三次或三次以上的数据

建一张表如下:表名为 number

1.1 要求找出num列连续出现三次或三次以上的数据:

select * from number where id in (
select distinct n1.id from number n1,number n2,number n3
where (n1.num = n2.num and n2.num = n3.num and (
(n1.id + 1= n2.id and n2.id +1 = n3.id)or
(n3.id + 1= n2.id and n2.id +1 = n1.id)or
(n3.id + 1= n1.id and n1.id +1 = n2.id)
)
)
order by n1.id )

运行结果:

1.2找出上表(运行结果表)中重复数据中id最小的数据。

思想:将上表中的数据分组取最小。

select min(id) as minid,id,num
from ((select * from number where id in (
select distinct n1.id from number n1,number n2,number n3
where (n1.num = n2.num and n2.num = n3.num and (
(n1.id + 1= n2.id and n2.id +1 = n3.id)or
(n3.id + 1= n2.id and n2.id +1 = n1.id)or
(n3.id + 1= n1.id and n1.id +1 = n2.id)
)
)
order by n1.id ))as t) group by num ;

运行结果:

2.删除表中的重复数据,保留id最小的数据

原表中的数据如下:

/*
方法一:
1.创建临时表
2.将需要的数据保存到临时表
3.清空原表,将临时表中的数据保存到原表中
4.删除临时表
*/
create temporary table temp select min(id),email from test group by email; truncate table test; insert into test select * from temp; select * from test; drop table temp; /*
方法二:
1.按照邮件分组,把每一组中的最小的id取出放在临时表中 2.删除原表中除临时表中id以外的其他id 对应的数据
*/ create temporary table temp select min(id) as minid from test group by email; delete from test where id not in (select minid from temp); drop table temp; /*
方法三:
在原表上操作
*/
delete from test where id not in (
select minid from (
select min(id) minid from test group by email
)b
);
select * from test;

运行结果:

3.mysql中的各种连接

创建两张表,代表两个店铺,每个店铺有不同的,每个柜台卖不同的商品。

/*
两个商店,每个店有不同的柜台,每个柜台上卖有不同的商品
*/
create table tableA(
id int(10) not null primary key auto_increment,
monorail varchar(20),
variety varchar(50)
);
insert into tableA
values (1,'a1','苹果'),(2,'a1','梨'),(3,'a3','香蕉'),(4,'a4','苹果'),(5,'a5','西瓜'),
(6,'a6','苹果'),(7,'a7','葡萄'),(8,'a8','桃子');
create table tableB(
id int(10) not null primary key auto_increment,
monorail varchar(20),
variety varchar(50)
);
insert into tableB
values (1,'b1','虾'),(2,'b2','猪肉'),(3,'b3','苹果'),(4,'b4','西瓜'),(5,'b5','梨'),
(6,'b6','香蕉');

两个表数据如下:

3.1.内连接

/*
内连接,查处两个商店共有的商品
*/
select * from tablea A INNER JOIN tableb B
on A.variety = B.variety ;

运行结果

3.2.左连接

/*
左连接,以A表为左表
*/
select * from tablea A LEFT JOIN tableb B
on A.variety = B.variety ;

运行结果

3.3.右连接

/*
右连接,以A表为左表
*/
select * from tablea A RIGHT JOIN tableb B
on A.variety = B.variety ;

运行结果

3.4.左外连接

/*
左外连接,以A表为左表
*/
select * from tablea A LEFT JOIN tableb B
on A.variety = B.variety Where B.variety is null;

运行结果

3.5.右外连接

/*
右外连接,以A表为左表
*/
select * from tablea A RIGHT JOIN tableb B
on A.variety = B.variety Where A.variety is null;

运行结果

3.6.全连接 

mysql不支持full  (outer) join 故使用union代替

/*
全连接
*/
select * from tablea A LEFT JOIN tableb B
on A.variety = B.variety ;
union
select * from tablea A RIGHT JOIN tableb B
on A.variety = B.variety ;

运行结果

3.7.全外连接

select * from tablea A LEFT  JOIN tableb B
on A.variety = B.variety Where B.variety is null
union
select * from tablea A RIGHT JOIN tableb B
on A.variety = B.variety Where A.variety is null

运行结果

mysql中各种复杂的增删改查的更多相关文章

  1. 用CI框架向数据库中实现简单的增删改查

    以下代码基于CodeIgniter_2.1.3版 用PHP向数据库中实现简单的增删改查(纯代码)请戳 http://www.cnblogs.com/corvoh/p/4641476.html Code ...

  2. MySQL数据库之表的增删改查

    目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...

  3. MYSQL - database 以及 table 的增删改查

    MYSQL - database 以及 table 的增删改查 MySQL的相关概念介绍 MySQL 为关系型数据库(Relational Database Management System), 这 ...

  4. 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理

    一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...

  5. 在ASP.NET MVC4中实现同页面增删改查,无弹出框02,增删改查界面设计

    在上一篇"在ASP.NET MVC4中实现同页面增删改查,无弹出框01,Repository的搭建"中,已经搭建好了Repository层,本篇就剩下增删改查的界面了......今 ...

  6. 在python中连接mysql数据库,并进行增删改查

    数据库在开发过程中是最常见的,基本上在服务端的编程过程中都会使用到,mysql是较常见的一种数据库,这里介绍python如果连接到数据库中,并对数据库进行增删改查. 安装mysql的python扩展 ...

  7. MYSQL的常用命令和增删改查语句和数据类型

    连接命令:<a href="http://lib.csdn.net/base/mysql" class='replace_word' title="MySQL知识库 ...

  8. MYSQL的常用命令和增删改查语句和数据类型【转】

    连接命令:<a href="http://lib.csdn.net/base/mysql" class='replace_word' title="MySQL知识库 ...

  9. nodejs+express+mysql实现restful风格的增删改查示例

    首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...

随机推荐

  1. 盘姬工具箱WV1.10

    ========================================================================== {盘姬工具箱CruiserEXPforWin版是一 ...

  2. Django(三) 模型:ORM框架、定义模型类并创建一个对应的数据库、配置Mysql数据库

    一.模型概述 https://docs.djangoproject.com/zh-hans/3.0/intro/tutorial02/ https://www.runoob.com/django/dj ...

  3. 搭建selenium+Python+eclipse 的开发环境

    下载安装Python,下载“python-2.7.9.msi”后可直接安装 下载安装setuptools,下载setuptools-11.3.1后,用命令提示符转到安装包中setup.py所在的位置, ...

  4. codeforces 586B:Laurenty and Shop

    B. Laurenty and Shop time limit per test 1 second memory limit per test 256 megabytes input standard ...

  5. POJ 3252:Round Numbers

    POJ 3252:Round Numbers Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 10099 Accepted: 36 ...

  6. Windows 下 GNS3 安装与基本使用指南

    1.GNS3简介 GNS3是一款图形化的网络虚拟软件,可以运行在多个平台(windows,linux,mac OS).我们可以通过它来学习Cisco的认证,或者是检验将要在生产环境中部署实施的相关配置 ...

  7. 前端解析返回的对象时json显示$ref问题的解决

    在mapper中写的语句,结果集中association,采用的一个对象,整个list列表中每个元素有一个对象元素,如果第二个元素中有一个与第一个元素中对象同名的,就会去引用上一个元素的地址,在jso ...

  8. 一百零六、SAP的OOP面向对象编程,OO-ALV的简介

    面向对象编程,如图 基本概念: 1.对象(Object)是一个现实实体的抽象.一个对象可被认为是一个把数据(属性)和程序(方法)封装在一起的实体,这个程序产生该对象的动作或对它接受到的外界信号的反应. ...

  9. 083-PHP的foreach循环

    <?php $arr = array(1, 2, 3, 4); foreach ($arr as &$value) { $value = $value * 2; } print_r($a ...

  10. 导出execl

    string filepath = Utils.GetMapPath("/upload/excel/"); filepath = filepath + fileName + &qu ...