首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

我是一个MySQL小白

我是一个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 * FROMcustomers,orders;返回的是两张表记录的笛卡尔积。(隐式查询:不使用关键字)

或者

SELECT * FROMcustomers CROSS JOIN orders;

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

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

或者

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

c、外连接:

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

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

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

右外:(右边为主)

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

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

2、几个简单的子查询

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

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

SELECT s_id FROMteacher_student WHERE t_id=1;

SELECT * FROM studentsWHERE id IN (1,2);

子查询:

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

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

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

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180726G1DJ8Q00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券