」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 從Mysql伺服器讀取數據

從Mysql伺服器讀取數據

發佈於2024-07-30
瀏覽:483

Reading data from Mysql server

匯入所需的包,然後準備一個與資料庫中tb_student表的範例具有相同模式的結構體,稍後該結構體將用作查詢結果的容器資料類型。

package main
import "fmt"
import "database/sql"
import _ "github.com/go-sql-driver/mysql"


type student struct {
 id string,
 name string,
 age int,
 grade int,
}

使用的資料庫驅動程式需要使用_符號導入,因為儘管database/sql包需要它,但我們不會直接與驅動程式互動。

接下來,建立一個連接資料庫的函數。

func connect() (*sql.DB, error) {
 db, err := sql.Open("mysql","root:@tcp(127.0.0.1:3306)/db_learn_go")
 if err != nil {
  return nil, err
 }
 return db, nil
}

我們使用的mysql 驅動程式的連接字串方案非常獨特,下面的root@tcp(127.0.0.1:3306)/db_learn_go 是可以在go MYSQL Driver 驅動程式上使用的連接字串方案,如果您使用另一個mysql,根據所使用的驅動程序,連接方案可能會有所不同。

user:password@tcp(host:port)/dbname
user@tcp(host:port)/dbname

下面是對 connect() 函數中使用的連接字串的解釋。

root@tcp(127.0.0.1:3306)/db_learn_go
// user => root
// password =>
// host => 127.0.0.1 atau localhost
// port => 3306
// dbname => db_learn_go

連接資料庫的功能建立完成後,就可以練習從資料庫伺服器讀取資料的過程了。準備函數
sqlQuery() 具有以下程式碼。

func sqlQuery() {
 db, err := connect()
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 defer db.Close()
 var age = 27
 rows, err := db.Query("select id, name, grade from tb_student where age = ?
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 defer rows.Close()
 var result []student
 for rows.Next() {
 var each = student{}
 var err = rows.Scan(&each.id, &each.name, &each.grade)
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 result = append(result, each)
 }
 if err = rows.Err(); err != nil {
 fmt.Println(err.Error())
 return
 }
 for _, each := range result {
 fmt.Println(each.name)
 }
}

每次建立新連線時,不要忘記始終關閉連線實例。您可以使用 defer 關鍵字,如上面的程式碼所示,defer
db.Close() .
db.Query()函數用於執行sql查詢。此函數的第二個參數是可變參數,因此可以留空。在上面的程式碼中,您可以看到其中一個where子句的值為問號(?)。

該符號將被其後面的參數中的值(年齡變數的值)取代。強烈推薦這種類型的查詢編寫技術,以防止 SQL 注入。此函數產生一個 sql.*Rows 類型的實例,當不再使用時也需要將其關閉( defer rows.Close() )。接下來,準備一個元素類型為 struct Student 且名稱為 result 的陣列。稍後查詢結果將儲存在變數中。然後執行循環,條件引用為 rows.Next() 。此循環執行的次數與記錄總數相同,從第一筆記錄到最後一筆記錄依序執行。 sql.Rows 的 Scan() 方法用於檢索正在迭代的記錄的值,並將其儲存在指標變數中。根據查詢中選擇的字段,用於儲存記錄字段的變數被順序寫入為可變參數。請參閱下面的比較以了解更多詳細資訊。 // 詢問
選擇身分證、姓名、年級...
// 掃描
rows.Scan(&each.id, &each.name, &each.grade ...
然後將所得的記錄資料透過語句
附加到結果切片中 結果 = 附加(結果,每個).
好的,現在只需在 main 中呼叫 sqlQuery() 函數,然後執行程式即可。

func main() {
sqlQuery()
}

我只是一個普通的部落客。如果還有太多不足之處還請見諒。

版本聲明 本文轉載於:https://dev.to/sukmarizki04/reading-data-from-mysql-server-2gcp?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何在Java列表中有效計算元素的發生?
    如何在Java列表中有效計算元素的發生?
    計數列表中的元素出現在列表 中,在java編程中,列舉列表中列舉元素出現的任務來自列表。為此,收集框架提供了全面的工具套件。 在這種情況下,Batocurrences變量將保持值3,代表動物列表中的“ BAT”出現的數量。 &&& [此方法是簡單的,可以得出準確的結果,使其成為計算列表中元素出現的...
    程式設計 發佈於2025-02-06
  • \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    \“(1)vs.(;;):編譯器優化是否消除了性能差異?\”
    使用(1)而不是(;;)會導致無限循環的性能差異? 現代編譯器,(1)和(;;)之間沒有性能差異。 是如何實現這些循環的技術分析在編譯器中: perl: S-> 7 8 unstack v-> 4 -e語法ok 在GCC中,兩者都循環到相同的彙編代碼中,如下所示:。 globl t_時 ...
    程式設計 發佈於2025-02-06
  • C#中靜態變量的功率和局限性是什麼?
    C#中靜態變量的功率和局限性是什麼?
    [2 [2 靜態變量是C#的基本功能,在面向對象的編程中起著重要作用。 與實例變量不同,它們獨立於任何特定對象,維護在類的所有實例中共享的單個值。 [2 幾個關鍵好處使靜態變量有價值: 數據共享:靜態變量為在多個類實例之間共享數據提供了方便的機制。 這對於管理全局常數,應用程序設置或跟踪共享狀...
    程式設計 發佈於2025-02-06
  • 如何使用Python的記錄模塊實現自定義處理?
    如何使用Python的記錄模塊實現自定義處理?
    使用Python的Loggging Module 確保正確處理和登錄對於疑慮和維護的穩定性至關重要Python應用程序。儘管手動捕獲和記錄異常是一種可行的方法,但它可能乏味且容易出錯。 解決此問題,Python允許您覆蓋默認的異常處理機制,並將其重定向為登錄模塊。這提供了一種方便而係統的方法來捕獲...
    程式設計 發佈於2025-02-06
  • 為什麼MySQL返回錯誤2014:“當其他未封閉的查詢處於活動狀態時無法執行查詢”?
    為什麼MySQL返回錯誤2014:“當其他未封閉的查詢處於活動狀態時無法執行查詢”?
    的原因2014:無法執行查詢,而其他未封閉的查詢是活動的在執行無封閉的查詢並試圖執行另一個查詢之前從中撤回所有行時首先,MySQL返回錯誤“無法執行查詢,而其他未封閉的查詢處於活動狀態。” 仿真準備的語句 有幾種解決此錯誤的方法: 使用buffered Queries: 關閉光標:使用colle...
    程式設計 發佈於2025-02-06
  • 如何從PHP中的源URL中檢索重定向URL?
    如何從PHP中的源URL中檢索重定向URL?
    從php /S/2e34796f/l/0l0sliberoquotidiano0bit0cnews0c12735670ci0esaggi0eper0ele0er0er0eriforme0ecostituzionaliiechiactuiaieiechiaccherano0eee0eee0ee...
    程式設計 發佈於2025-02-06
  • 混合蛋白如何在沒有繼承的情況下提供可擴展的類功能?
    混合蛋白如何在沒有繼承的情況下提供可擴展的類功能?
    引入mixins:Intuitive class Extension無繼承概念在擴展類別的功能中起著至關重要的作用,而無需依賴傳統的繼承。 Mixins通常稱為“抽象子類”,為一個共同的挑戰提供了一種優雅的解決方案:結合正交概念,同時保持代碼模塊化和組合性。 理解了對Mixins 在軟件工程中,我...
    程式設計 發佈於2025-02-06
  • 對象擬合:IE和Edge中的封面失敗,如何修復?
    對象擬合:IE和Edge中的封面失敗,如何修復?
    解決此問題,我們採用了一個巧妙的CSS解決方案來解決問題:高度:100%; 高度:auto ; 寬度:100%; //對於水平塊 ,使用絕對定位將圖像定位在中心,以object-fit:object-fit :cover in IE和edge消除了問題。現在,圖像將按比例擴展,保持所需的效果而不...
    程式設計 發佈於2025-02-06
  • 可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    </main> <section> ,但无法使其正常工作,如您所见。任何洞察力都将不胜感激! display:grid; { position:sticky; top:1em; z-index:1 1 ; { { { pos...
    程式設計 發佈於2025-02-06
  • 如何在XAMPP上創建虛擬主機?
    如何在XAMPP上創建虛擬主機?
    [2 。更新hosts文件 127.0.0.1 localhost 127.0.0.1 [主機域名] 2。配置虛擬host ” Servername [主機域名] 3。 XAMPP \ apache \ apache \ conf \ conf \ httpd.conf中的uncomme...
    程式設計 發佈於2025-02-06
  • 如何使用char_length()在mySQL中按字符串長度對數據進行排序?
    如何使用char_length()在mySQL中按字符串長度對數據進行排序?
    [2使用內置的char_length()function。 char_length()和length() 此查詢將從指定的表中檢索所有行,並基於上升順序對它們進行排序指定列的字符長度。帶有更長字符串的行將出現在結果的底部。
    程式設計 發佈於2025-02-06
  • 在沒有密碼提示的情況下,如何在Ubuntu上安裝MySQL?
    在沒有密碼提示的情況下,如何在Ubuntu上安裝MySQL?
    在ubuntu 使用debconf-set-selections sudo debconf-set-selections
    程式設計 發佈於2025-02-06
  • 如何使用組在MySQL中旋轉數據?
    如何使用組在MySQL中旋轉數據?
    在關係數據庫中使用mysql組使用mysql組來調整查詢結果。在這裡,我們面對一個共同的挑戰:使用組的組將數據從基於行的基於列的基於列的轉換。通過子句以及條件匯總函數,例如總和或情況。讓我們考慮以下查詢: select d.data_timestamp, sum(data_id = 1 tata...
    程式設計 發佈於2025-02-06
  • 如何使用CSS檢測iPhone和iPad設備?
    如何使用CSS檢測iPhone和iPad設備?
    使用CSS檢測iPhone/iPad:故障排除和解決方案 iPhone and ipod touch: ipad: 通過將這些媒體查詢合併到樣式表中,您可以確保根據檢測到的設備類型應用特定的CSS樣式。這種方法提供了更大的靈活性,並允許您調整網站或應用程序的外觀到不同的iOS設備。
    程式設計 發佈於2025-02-06
  • 我應該在C ++中使用std :: string或std :: Wstring嗎?
    我應該在C ++中使用std :: string或std :: Wstring嗎?
    在C std :: string中的UTF-8,對Unicode術語有基本的理解是有幫助的: grapheme簇: std :: string vs. vs. vs.因素:[ 可移植:使用std :: u32String(std : : basic_string ),而不是std :: wcha...
    程式設計 發佈於2025-02-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3