Jetbrains 系列的 IDE 都可以在開發的時候都可以擁有 SQL Intellisense,這將替我們解省掉打字所造成的除錯時間,Database Connection Windows 提供更方便的介面讓我們觀察資料庫的狀態,可以 CRUD(別直接用線上資料庫)、觀察執行計畫。
開發環境
- Rider 2021.1.1
- Windows 10
Database Connection
這個跟 VS IDE 的 SSDT 很類似,可以讓我們在開發工具直接控制資料庫,不同的資料庫連接除了 Driver / Provider 不同,操作步驟都是大同小異。
Ctrl+Alt+3 → New Data Source → SQLite Driver → DB Flie
data:image/s3,"s3://crabby-images/2bebe/2bebe6fe0b901df273978f63161bc2ae0a7466f0" alt=""
接下來就選 SQLite 的檔案和 Driver
data:image/s3,"s3://crabby-images/80802/808023fb15c05e05c86bb66527d517059c09b62b" alt=""
Driver 安裝路徑為 %userprofile%\AppData\Roaming\JetBrains\Rider2021.1\jdbc-drivers
完成之後就能夠,在開發 IDE 裡面直接控制資料庫了
data:image/s3,"s3://crabby-images/995e4/995e4c4e80602ce6b071af4f42654d21afee65d6" alt=""
參考:
Database connection | JetBrains Rider
Execute SQL Raw
Execute / Run Query in Console
- 鍵盤焦點停在 Sql Raw 內 → enter + alt → 輸入 run,選擇 Run query in console,或是按下 ctrl + enter
data:image/s3,"s3://crabby-images/20f64/20f6437a37ebecf479126ee9f0c1fea09e5ea125" alt=""
第一次使用會跳出 New Session 快選視窗,按下 enter
data:image/s3,"s3://crabby-images/6ef98/6ef98473076f8241324daf998bb46bcc03a2b65f" alt=""
這時會跳出另一個 Service Window,裡面會記錄你的查詢以及結果
data:image/s3,"s3://crabby-images/2435c/2435c87fea5984ea8d7a86a3eabbe15dcb41d3aa" alt=""
Database 變成連線狀態
data:image/s3,"s3://crabby-images/6554e/6554e461076809ebd7badee5f98edebe7c2ddbf0" alt=""
查詢過的結果可以
- 匯出檔案
- 觀察執行計畫
data:image/s3,"s3://crabby-images/e12cf/e12cf440f0b63d39ac2a6af67ac7b5ccd64c19df" alt=""
Execute to File
支援多種匯出格式
data:image/s3,"s3://crabby-images/12ae7/12ae72552a9ceb6a133c7ce64b8e7a474c5a7946" alt=""
Execute Plan
觀察有沒有吃到索引
data:image/s3,"s3://crabby-images/8aafb/8aafb36fa9f5622cf92ce9dce41f16fe4d26c70b" alt=""
SQL Dialects
Ctrl+Alt+S → 搜尋 dialects → SQL Dialects
SQL Dialects 的設定可分為 Global、Project、File 層級,這是在跟 IDE 講那些需要分析 SQL,完成之後編寫 SQL Raw 的時候就會有 Instellisense、Reformat Code 的功能了
下圖我設定 Project 層級
data:image/s3,"s3://crabby-images/b86ed/b86ed60c8fcb564caf924ce8b7b5f6d7008b70ec" alt=""
產生 sql dialects,鍵盤焦點停在 SQL Raw → alt + enter,跳出 Change dialects
data:image/s3,"s3://crabby-images/3fb57/3fb57322a729678de3280bc6b38e03cdb5911ee6" alt=""
Instellisense
在 C# 編寫 SQL Raw 也可以有 Instellisense
data:image/s3,"s3://crabby-images/066e4/066e48c10617112a46eb538ede3022a534e688a6" alt=""
Analytic SQL Raw
解析語法,幫你標出有問題的地方,不過這不影響 C# 編譯
data:image/s3,"s3://crabby-images/1db57/1db57795aadf1ec717dc668b21b407e0536cb00d" alt=""
參考:
SQL Dialects | JetBrains Rider
若有謬誤,煩請告知,新手發帖請多包涵
Microsoft MVP Award 2010~2017 C# 第四季
Microsoft MVP Award 2018~2022 .NET