朋友们,想转行数据吗?那我的第一个问题就会是,你会写SQL吗?
之前有推荐过几个SQL的课程,其实有了ChatGPT之后,连SQL课程都不需要了。甚至连在电脑上安装SQL,这件曾经让我很崩溃,几乎要放弃SQL的事情也不需要了。家庭教师ChatGPT都可以提供!
[ ⚠️ ]以下会有大量中英文夹杂,因为我不会翻译,介意的朋友可以优雅离场了。
今天来分享一下我测试ChatGPT来学习SQL的全过程,以及我用的prompt。有了ChatGPT,只要会打字就能学会SQL!
以下内容包括:
- 让ChatGPT给一个study plan;
- 让ChatGPT给题目,不要给答案,并且visualize 表格;
- 让ChatGPT分析解题思路;
- 让ChatGPT出面试题目;
- 让ChatGPT辅导写Leetcode
直接开始!
i don't have SQL on my computer, can you act as mysql
首先我问了ChatGPT它可不可以act as SQL server。它说不行。但是后面测试的时候,只要在对话框里打SQL syntax,它就可以理解啦。所以不用担心!
what are the most basic sql i should know about
接着我问它需要知道SQL最基础的内容。它给了回答。
data:image/s3,"s3://crabby-images/9ca1a/9ca1a30dfa6418edcaec86e37885b788229b8fb7" alt="Screenshot 2023-03-20 at 2.24.18 PM.png"
can you come up with a study plan for SQL. i want to learn the basics one by one with practices.
data:image/s3,"s3://crabby-images/eeb68/eeb688c7625c950d53ebaf868fddb3286e6ed3b2" alt="Screenshot 2023-03-20 at 3.01.19 PM.png"
can you give me a basic sql question practicing select statement only. please do not give me answer yet. please visualize the example tables with examples.
下一步的话,我们就可以开始练习啦!可以从最上面的一条SELECT
开始,让ChatGPT出题目。记得让它不要给答案先哦。并且可以让它数据的时候可以给一个例子。
data:image/s3,"s3://crabby-images/fbb7f/fbb7f60d295aa1560406f7a60e40f5ca0d2713cf" alt="Screenshot 2023-03-20 at 2.29.07 PM.png"
data:image/s3,"s3://crabby-images/af4c5/af4c56c70d0d8a666a515f544507c6e42c49080a" alt="Screenshot 2023-03-20 at 2.29.15 PM.png"
how should i start thinking about this question.
但是我完全不会写SQL怎么办呢,那就问家庭教师呀。(不得不说,思路很清晰!)
data:image/s3,"s3://crabby-images/7e60b/7e60b16d397ff3a0bd1dfa81ceeed7d152c6362b" alt="Screenshot 2023-03-20 at 2.31.08 PM.png"
data:image/s3,"s3://crabby-images/e9867/e986797801a443b62d30d89f58e3017e1d337294" alt="Screenshot 2023-03-20 at 2.31.14 PM.png"
到这里,我们就可以开始写写看。我故意写了错的答案,看一下它会怎么指导我。
select first name, last name, salary, from employees where salary >1000
data:image/s3,"s3://crabby-images/35622/35622f015acd51e7a60b0ad06e236421afa9260d" alt="Screenshot 2023-03-20 at 2.34.55 PM.png"
这个题目比较简单。JOIN
是面试的时候经常会考到的题目,并且会考不同的JOIN之间的区别。所以我让ChatGPT给我一道JOIN的题目,但是不要告诉我是哪一种JOIN。
i want to practice join, including INNER JOIN, LEFT JOIN, RIGHT JOIN, and FULL OUTER JOIN. please give me a question to practice one of the joins. do not tell me which type of join i should use. visualize the example tables.
data:image/s3,"s3://crabby-images/35dd4/35dd45dcea10cf645d05cde91a33a27fec685233" alt="Screenshot 2023-03-20 at 2.38.01 PM.png"
how the output should look like? can you visualize the output table
如果你觉得这个题目有一点点复杂,可以先让ChatGPT给一个output的样子,帮助理解。
data:image/s3,"s3://crabby-images/34942/34942af1bca851136678ef2516a9a3c52314f0b1" alt="Screenshot 2023-03-20 at 2.40.11 PM.png"
how should i think about this question
还是觉得有一点不知道如何下手,那就让ChatGPT一步步拆解。
data:image/s3,"s3://crabby-images/b392b/b392b7c02c997c128a68597c43eec2ffc201bcdc" alt="Screenshot 2023-03-20 at 2.41.52 PM.png"
how to determine which type of join to use in this question?
在关于JOIN的题目里,决定哪一种JOIN是最重要的一步,我们也可以问ChatGPT。
data:image/s3,"s3://crabby-images/e2c82/e2c82c8eb2d628fe9f0c2e7939d7bff42451d66b" alt="Screenshot 2023-03-20 at 2.45.12 PM.png"
select first_name, last_name, department_name, salary from employees join departments on department_id = department_id
这里我又故意给了错误的回答,在department_id前面没有加上table的名字。
ChatGPT就指出了这个错误,并且教我使用aliases。
data:image/s3,"s3://crabby-images/707f7/707f75b0e1d7730e7505b086811951ecef4545fe" alt="Screenshot 2023-03-20 at 2.48.43 PM.png"
在各种练习之后,我们可以开始准备面试了!
can you find a question used by facebook during data engineer interview
data:image/s3,"s3://crabby-images/342d9/342d9ad963090b6f18570bed6483e45f54ae4977" alt="Screenshot 2023-03-20 at 2.49.55 PM.png"
can you give me a more complex question that has been used in data engineer interviews
上面这个问题有一点点太简单啦,我就问有没有更难的问题。
data:image/s3,"s3://crabby-images/98186/981867ee0dcc82acd7cd3462184697c31dac578b" alt="Screenshot 2023-03-20 at 2.51.31 PM.png"
最后的话来看一下ChatGPT如何辅导Leetcode SQL题目。 我随便找了一道Leetcode database的题目,https://leetcode.cn/problems/second-highest-salary/,复制粘贴给ChatGPT。
data:image/s3,"s3://crabby-images/1d0cb/1d0cbd92307dbd1f0419eb93c6cd597beb258468" alt="Screenshot 2023-03-20 at 3.12.55 PM.png"
can you explain?
data:image/s3,"s3://crabby-images/39ee0/39ee0b19940ed49bab92d7f9a661fc923463a223" alt="Screenshot 2023-03-20 at 3.14.44 PM.png"
what if we want to get the Nth highest salary?
data:image/s3,"s3://crabby-images/aca8c/aca8c17a759c76b35422815f7a83de392e78346e" alt="Screenshot 2023-03-20 at 3.16.44 PM.png"
what does 'LIMIT n-1, 1 ' mean?
这里出现了一个新的概念Offset,于是就追问一下。
data:image/s3,"s3://crabby-images/33e30/33e3087022c2b36900fec173aaefc7592aeb8cad" alt="Screenshot 2023-03-20 at 3.18.55 PM.png"
总结一下:
上面是我测试如果用ChatGPT来自学SQL的实录。总结一下:
- ChatGPT教得很好;
- SQL最主要的学习方式就是练习以及解题思路,可以让ChatGPT给很多练习题,并且让它给出如何一步步思考的过程;
- 遇到不会写的题目,就拿给ChatGPT吧!
About Me:
很开心遇见你!我是穿堂风,也是Simona。曾经的资深互联网数据打工人(Data Engineer),2022年11月被Facebook裁员后,开启数字游民生活。
我正在做的项目和提供的服务在我的个人主页。https://simona.life/