我是一个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 * 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);

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

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

 

 

欢迎您的阅读,本人微信公众号  "欢乐的马小纪"欢迎关注

 

 

posted @ 2018-07-26 17:25  欢乐的马小纪  阅读(553)  评论(4编辑  收藏  举报