"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > كيفية استيراد البيانات من STDIN إلى PostgreSQL باستخدام حزمة Go\'s pq؟

كيفية استيراد البيانات من STDIN إلى PostgreSQL باستخدام حزمة Go\'s pq؟

تم النشر بتاريخ 2024-11-17
تصفح:753

How to Import Data from STDIN to PostgreSQL Using Go\'s pq Package?

كيف يمكنني استيراد الصفوف إلى Postgresql من STDIN؟ [مكررة]

في Go، يمكنك استيراد الصفوف إلى PostgreSQL من STDIN باستخدام الحزمة pq. إليك الحل خطوة بخطوة:

الخطوة 1: إعداد اتصال قاعدة البيانات

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)
}

الخطوة 2: بدء المعاملة

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 الخاص بك.

بيان الافراج أعيد طبع هذه المقالة على: 1729744624 إذا كان هناك أي انتهاك، يرجى الاتصال بـ [email protected] لحذفه
أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3