你是一个MySQL小白么?

第一回早起装扮

“mysql,Oracle,SQL-SERVER你们三个 起床没?”,清晨七点多师父喊道。

“师父,我(mysql)哪敢睡觉呀,我还在查询表呢,有客户的密码忘记了,要我查一下回复他”,我自顾不暇地回答着师父。

“那你赶紧快一点,一会收拾一下,我要领你们几个去一个神秘的地方”,师父说道,

“神秘地方?好呀”,我疑惑着答道。

在数据界混这么多年还有我不知道的地方?师父今天好奇怪,不想了,我赶紧收拾着面前的数据表,已经半年没出山了,马上就要出去了,我要把自己收拾得利索点。

拿着镜子,我眼看着身上那么多的“子查询语句”,我狠狠拍了一下自己的脑袋,心里暗暗觉得服务器主人太不通情达理了,天天催我加班加点干活赶工期,难怪我把自己弄的这么糟糕,好久没看到这样的自己了,真是难看极了。今天我一定好好捯饬捯饬,我把身上的“子查询语句”换成了“连接JOIN”语句,使用“联合(UNION)”来代替手动创建的“临时表”,优化完毕,终于忙完了,看着数据查询传输极快,嘿嘿,瞬间感觉自己长得相当哇塞。

收拾完,我往客厅走着,没注意地往Oracle大师兄房间里看了一眼,一瞬间我呆住了。

二师兄SQL-SERVER也收拾完了,看我傻傻的样子忍不住问道,“看什么呢三弟,看你那呆若木鸡的样子”,然后他也顺着我的目光望去,二师兄看完也傻眼了。我惊讶地问着二师兄:“大哥这数据传输也太厉害了吧,天呐,多么巨大的访问量啊,多么巨大的并发量啊”。二师兄低声说道:“厉害吗?能有我厉害?”。我扭头看着二师兄认真的模样,送给他一副不屑的表情。

“都收拾好了吗?”师父喊道。

“好啦”。我们三个应声答道,我们三个陆陆续续来到了客厅。

第二回华山论剑

吃完早饭。

师父从车库把车开了出来,一打开车门,我们三个就哄抢着坐下。师父开着车子经过了三座大山,终于停在了一家旅馆面前。旁边立着一个牌子写着:“华山数据库排名争霸赛”,难道这就是师父所指的神秘地方,十年磨一剑,大师兄二师兄早就想在数据库大赛上面一展身手,他们做梦就等着这一刻呢,我并没有什么特别的想法。

休息半日,师父把我们领进入主赛场地。

大师兄纵身一跃首先登场,大声喝到:

“在下oracle 是大型的数据库,体积大。可以支持多个实例同时运行,功能异常强大”。

“哪里来的毛贼,居然敢来这里叫嚣,你有我处理速度快吗?哈哈哈”,只看到一个挂着redis牌子的家伙叫嚣到。

Redis?我的天,这不是非关系型数据库吗?它可以自由自在地在内存里运行,号称数据库界的飞毛腿,这下完了,大师兄一定不是对手,希望大师兄不要和他在这方面一比高下。

“就凭你?不服来干”,大师兄轻蔑笑道.然后他们开始同时查询数据,Redis 用了30s 的时间就处理2000次请求,100W个ID的查询,大哥那边忙的手忙脚乱,还迟迟没有出来结果。

大师兄中计了,为什么不扬长避短呢,也难怪,他压根不记得师父教导我们的事情了,我们数据库大致分为两类,一个是关系型数据库在磁盘上面运行,一个是非关系型数据库是在内存上面运行,我们师兄弟三个都是关系型数据库。

大师兄被拖下去了,二师兄登台。二师兄胸有成竹地问Redis:“你一个非关系型数据库拿速度和我们比算什么本事,有能耐你比一下并发量”。

Redis看着二师兄,哈哈大笑道:“就凭你那磁盘速度和我比并发量?回家问你师父你有几斤几两再说吧”;

眼看着二师兄要出糗,我觉得有必要登台了。

“大家好,我是mysql,今天来了很多的数据库大师,我一个后辈按理说不应该有说话的余地,但是在此心有不平,就放肆在此一吐为快吧”。

听完我说完,Redis叫嚣到,”你一个小辈滚下去”.

我一时气不过喊道,“你有我存储空间大?”,Redis一时语塞。

我继续说道:“天下比赛,无非都是拿自己的长处来和对手的短处来比,这样的想法早已经过时,既然大家都是数据仓库,传承一脉,理应互帮互助,这场大赛本就是一场友谊赛,大家求同存异互相学习,为什么要斗得脸红脖子粗,试问哪个数据库处理数据不是增删改查,在此我愿意分享我的数据接口,与大家共同来分享学习对方的存储方式,

我首先说的是我的多表查询:

1、链接查询:

a、交叉链接:

SELECT * FROM customers,orders;返回的是两张表记录的笛卡尔积。(隐式查询:不使用关键字)

或者

SELECT * FROM customers CROSS JOIN orders;

b、内连接:(根据where取交集)

SELECT * FROM customers c,orders o WHERE c.id=o.customer_id;

或者

SELECT * FROM customers c INNER JOIN orders o ON c.id=o.customer_id;

c、外连接:

查询所有的客户信息,同时把对应的订单查询出来。

左外:(左边为主)返回符合链接条件的记录,同时返回左表中不满足链接条件的剩余记录

SELECT * FROM customers c LEFT OUTER JOIN orders o ON c.id=o.customer_id;

右外:(右边为主)

SELECT * FROM customers c RIGHT JOIN orders o ON c.id=o.customer_id;

外连接 = 内连接+其中一个表的剩余部分

在这里插入图片描述

2、几个简单的子查询

嵌套查询,子查询的语句放到小括号之内。

ID=1的这个老师教过哪些学员(语句的查询形式:多条SQL语句)

SELECT s_id FROM teacher_student WHERE t_id=1;

SELECT * FROM students WHERE id IN (1,2);

子查询:

SELECT * FROM students WHERE id IN (SELECT s_id FROM teacher_student WHERE t_id=1);

听我说完之后,大家觉得再比下去反倒让一些后生看不上,这位后生说的也不无道理,也就从摩拳擦掌到故意掌声雷动,大家都开始各显身手互相学习,友谊赛变成了开开心心的大团聚。

大师兄二师兄下台之后显得更加谦逊了。师父责怪我斗志不够,但是看着大家团结互助,我的心中还是很开心的。

在这里插入图片描述
上面是我收集的一些视频资源,在这个过程中帮到了我很多。如果你不想再体验一次自学时找不到资料,没人解答问题,坚持几天便放弃的感受的话,可以加入我们扣扣群【313782132 】,里面有各种软件测试资源和技术讨论。

软件测试是IT相关行业中最容易入门的学科~不需要开发人员烧脑的逻辑思维、不需要运维人员24小时的随时待命,需要的是细心认真的态度和IT相关知识点广度的了解,每个测试人员从入行到成为专业大牛的成长路线可划分为:软件测试、自动化测试、测试开发工程师 3个阶段。

如果你不想再体验一次自学时找不到资料,没人解答问题,坚持几天便放弃的感受的话,可以加我们的软件测试交流群,里面有各种软件测试资料和技术交流。

猜你喜欢

转载自blog.csdn.net/weixin_50271247/article/details/109166789
今日推荐