ChatGPT可以做很多很酷的事情。其中之一就是寫程式碼。使用者只需要給出正確的指令,ChatGPT就會完成這項工作。
如果你想學習SQL,ChatGPT是一個很好的入門資源。它可以幫助你用自然語言建立SQL查詢,解決可能遇到的任何編碼問題,甚至幫助你理解你不理解的預先定義查詢。
本文將概述如何使用ChatGPT來學習SQL,並熟練這項寶貴的技能。
ChatGPT是一個由OpenAI訓練的大型語言模型。它能夠根據收到的輸入產生類似人類的文本,並可用於回答問題和與人進行對話。
所以基本上,用戶可以利用它的知識 --以及它以非常簡單和人性化的方式告訴用戶任何事情的能力--來理解SQL並從中學習。
要開始使用ChatGPT,需要在ChatGPT|OpenAI官網註冊一個帳戶。
ChatGPT註冊介面
必須提供電子郵件地址和電話號碼才能開始使用ChatGPT。
一旦啟用了ChatGPT,應該會看到以下顯示:
ChatGPT聊天顯示的截圖
在下面的輸入框中,使用者可以寫下任何東西來開始與ChatGPT互動。
ChatGPT回覆了我的第一個訊息。
所以現在可以開始問ChatGPT任何問題。本文將專注於學習SQL。透過使用ChatGPT,我們可以要求做5件主要的事情來提升我們的SQL技能。
當遇到新的程式語言時,我們通常會對每一個指令都有很多疑惑和困惑。 ChatGPT可以透過簡單的解釋來幫助理解任何命令,並根據要求提供盡可能多的用法範例。
本文從SQL中最基本的東西開始-SELECT指令。
請簡短地解釋什麼是SELECT指令,並舉例說明如何使用它。
ChatGPT回答了一個解釋SELECT指令的簡短答案,並給了最基本的例子:SELECT*FROM。
ChatGPT聊天的截圖。
但是,可以進一步詢問SELECT指令。
請解釋一下什麼是SELECT指令以及一些示範如何使用它的範例。
如如你在下面的圖片中所觀察到的,ChatGPT解釋了該指令基本原理的內容,並給出了一些使用的例子。
ChatGPT聊天的截圖。給出了更多SELECT指令的例子。
可以試著問任何能想像到的指令,比如說一個更有挑戰性的指令,如HAVING。
給我一些SQL中的HAVING指令的範例。
而ChatGPT給出瞭如下幾個例子來回答:
<code>SELECT name, salaryFROM employeesGROUP BY nameHAVING salary > (SELECT AVG(salary) FROM employees);</code>
<code>SELECT name FROM customers WHERE customer_id IN (SELECT customer_id FROM orders WHERE date >= DATEADD(year, -1, GETDATE()) GROUP BY customer_id HAVING COUNT(*) > 10);</code>
當然,可以繼續要求更多的解釋和更多的例子。試試能想到的任何其他命令,它馬上就會回答。
可以問如何做一個特定的動作,ChatGPT會讓我知道我需要使用什麼指令。
我想合并两个表,应该在SQL中使用什么命令?
ChatGPT回答可以使用任意join命令,可以在下面的图片中看到:
ChatGPT聊天的截图。解释如何合并两个表格。
然而,我知道我只是想在某些特定列中的行有重合值时连接两个表。在这种情况下,我可以再询问一下,了解一下我应该使用什么命令。
我想连接两个表,只获取在某些给定的列中有一致值的数据。
我想连接两个表,只想获得在某些给定列中有重合值的数据。
因此,ChatGPT让我知道只有INNER JOIN允许这样做,可以在下面的图片中看到:
ChatGPT聊天的截图。解释了如何合并两个表,并只是保持重合的数值。
它给出了相应的查询:
<code>SELECT *FROM table1INNER JOIN table2 ONtable1.id = table2.id AND table1.name = table2.name;</code>
现在让我们想象一下,我知道我需要什么结果,但我没有如何制定这个查询的任何想法。我可以简单地向ChatGPT解释我想做什么,它就会给我一个让我遵循的结构。因此,我可以按照ChatGPT的例子学习如何构造查询。
请向我解释一下如何创建一个SQL查询,计算出欧洲最昂贵的城市,并在表中列出每个城市不同商品的价格。
ChatGPT马上回答我,你可以在下面的图片中看到:
ChatGPT给出了一个查询的例子,并解释了这个查询的作用。
现在让我们想象一下,你正在做从一个生病的同事那里接手的工作,但是你不理解他的查询——有些人的编码方式很混乱,或者你可能只是觉得很懒,不想浪费太多时间去理解别人的查询。
这很正常——可以用ChatGPT来避免这项任务。我们可以很容易地要求ChatGPT解释一个给定的查询。
假设我们想了解下面这个查询是做什么的:
下面的查询是做什么的:[在此插入查询]
ChatGPT就会马上回答:
ChatGPT聊天的截图。它解释了一个给定的查询是做什么的。
正如在前面的图片中所看到的,ChatGPT一步一步地解释了这个查询的作用。
首先,它解释了所有包含的子查询和它们的作用。然后,它解释了最终的查询,以及它如何使用前面的子查询来合并所有的数据。我们甚至可以要求在一个给定的子查询中提供更详细的解释。
你能进一步解释前面查询的第二个子查询是做什么的吗?
ChatGPT聊天的截图。它进一步解释了给定查询的第二个子查询的作用。
正如在前面的图片中所看到的,ChatGPT详细解释了第二个子查询的内容。
用户可以用能想到的任何查询来挑战ChatGPT!
ChatGPT最好的部分就是可以要求它提供一些练习和答案来练习和测试你的技能。它甚至可以告诉你,你什么时候做得好——或者不好。
你能給我一些練習來練習SQL嗎
#ChatGPT的截圖,給我一些練習SQL的練習。
現在ChatGPT告訴我一些需要執行的問題。在這種情況下,我可以嘗試解決第一個問題,並詢問ChatGPT我的解決方案是否正確。
下面的查詢對於前面第一個練習的答案是否正確[插入查詢]
#ChatGPT將回答並寫出是否正確及原因。
ChatGPT的截圖,回答我編碼的查詢是否正確。
我可以問前面每個例子的正確答案:
你能給我前面練習的正確答案嗎?
而在下面的圖片中可以看到,ChatGPT會給出我所有正確的查詢結果。
⚠️注意到ChatGPT提供給我的答案和我提供的被檢查的答案是完全不同的。
在今天這個由數據驅動的世界裡,SQL是一項有價值的技能。透過使用ChatGPT來學習基礎知識和練習技能,可以熟練SQL。透過持續的學習和練習,可以繼續擴大你的技能,並使用這個工具在你的數據職業生活中實現飛躍。
以上是學習效率翻倍,用ChatGPT學習SQL資料分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!