في Go، يمكنك استيراد الصفوف إلى PostgreSQL من STDIN باستخدام الحزمة pq. إليك الحل خطوة بخطوة:
import (
"database/sql"
"github.com/lib/pq"
)
db, err := sql.Open("postgres", "dbname=mydb user=myuser password=mypassword")
if err != nil {
log.Fatalf("open: %v", err)
}
txn, err := db.Begin()
if err != nil {
log.Fatalf("begin: %v", err)
}
الخطوة 3: تحضير بيان النسخاستخدم pq.CopyIn() لإنشاء بيان مُجهز.stmt, err := txn.Prepare(pq.CopyIn("test_table", "column1", "column2", ...))
if err != nil {
log.Fatalf("prepare: %v", err)
}
الخطوة 4: تنفيذ بيان النسخالتكرار من خلال بياناتك وتنفيذ stmt.Exec() لكل صف.for _, row := range rows {
_, err = stmt.Exec(row.Column1, row.Column2, ...)
if err != nil {
log.Fatalf("exec: %v", err)
}
}
الخطوة 5: تنفيذ بيان النسخة النهائية_, err = stmt.Exec()
if err != nil {
log.Fatalf("exec: %v", err)
}
الخطوة 6: إغلاق البيان وتنفيذ المعاملةstmt.Close()
err = txn.Commit()
if err != nil {
log.Fatalf("commit: %v", err)
}
سيعمل هذا الرمز على استيراد الصفوف بكفاءة من STDIN إلى جدول PostgreSQL الخاص بك. تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3