前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql嵌套语句的应用

Mysql嵌套语句的应用

作者头像
用户5166556
发布2019-04-16 11:27:53
1K0
发布2019-04-16 11:27:53
举报
文章被收录于专栏:让技术和时代并行
代码语言:javascript
复制
INSERT INTO books (name) SELECT 'MySQL Manual' FROM dual WHERE NOT EXISTS (SELECT id FROM books WHERE id = 1)

duan关键词和not exists联合使用我们可以进行判断如果数据库存在则不进行插入,不存在则插入。

实例:我找了一个比较复杂的。

代码语言:javascript
复制
INSERT INTO `user`(id, username, password,sex, email,headImg,blogUrl,feeling,registDate) 
SELECT 
100,'helllo','6ece8b29849534227ca38d459c28d9f8',1,'iveryang@sina.cn',	
'http://static.tieba.baidu.com/tb/editor/images/tsj/t_0002.gif','http://iver.cloudfoundry.com','天下风','2013-05-09' 
FROM DUAL WHERE NOT EXISTS (SELECT id FROM `user` WHERE id=100);

这里的dual实际上是一个虚拟表。一定要使用dual,然后才能进行判断之后把数据进行插入操作。

2:between and 的使用

between and在进行日期判断时是非常常用的操作,但是它只判断两个边界值。如果时间后面跟有时 分 秒,那么有一部分数据将不能取到,如果要想取到,必须使用date函数进行操作,不过这时你要衡量你的数据量的大小,通过date函数将不通过索引来查询。

实例:

代码语言:javascript
复制
select 字段名称 from 表的名称 where  DATE(DATETIME)  between ? and ? 

下面这是直接使用查询结果不一样

代码语言:javascript
复制
<pre name="code" class="sql">select 字段名称 from 表的名称 where  DATETIME  between ? and ? 
代码语言:javascript
复制

3:union使用

代码语言:javascript
复制
SELECT ...
UNION [ALL | DISTINCT] SELECT ...
[UNION [ALL | DISTINCT] SELECT ...]

实例:这里取得相当于并集

代码语言:javascript
复制
(SELECT a FROM t1 WHERE a=10 AND B=1 ORDER BY a LIMIT 10)
UNION
(SELECT a FROM t2 WHERE a=11 AND B=2 ORDER BY a LIMIT 10);

4:in的使用(嵌套查询使用实例)相当于使用交集

代码语言:javascript
复制
select * from 表名 where 字段名2=? and 字段名1 in ( select 字段名1 from 表名 where 字段名2=? ) ;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014年06月11日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档