"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > كيفية استخدام الانعكاس للاتصال بوظيفة DATABASE/SQL.

كيفية استخدام الانعكاس للاتصال بوظيفة DATABASE/SQL.

نشر في 2025-02-06
تصفح:792

How to Use Reflection to Call the Database/SQL Rows.Scan() Variadic Function?

استفسار. ومع ذلك ، فإنه يستخدم عددًا متغيرًا من المؤشرات كوسيطاتها ، والتي قد تكون صعبة في دمجها باستخدام التفكير. ضع في اعتبارك السيناريو التالي: تريد أن تملأ شريحة مع القيم التي تم الحصول عليها من الاستعلام واستخدام الصفوف. scan () لاستخراج البيانات. في هذه الحالة ، ستحتاج إلى تحديد عدد الأعمدة وإنشاء شريحة لتخزين القيم. قد تؤدي وظيفة SCAN () إلى نتائج غير متوقعة. وذلك لأن الصفوف. ] للاتصال بنجاح Scan () مع التفكير ، يتم استخدام نهج شريحة مزدوجة. الشريحة الأولى ، القيم ، تحمل البيانات الفعلية ، في حين أن الشريحة الثانية ، قيمها ، تحتوي على مؤشرات لكل عنصر في القيم.

في القيم. بعد ذلك ، يمكن استدعاء الصفوف. يستورد ( "FMT" _ "github.com/lib/pq" "قاعدة البيانات/SQL" ) Func Main () { DB ، _: = sql.open ( "postgres" ، "user = postgres dbname = go_testing password = pass sslmode = disable") صفوف ، _: = db.query ("حدد * من _user ؛") الأعمدة ، _: = الصفوف. columns () العد: = لين (أعمدة) القيم: = make ([] واجهة {} ، العد) DesignPtrs: = make ([] interface {} ، count) للصفوف. next () { لأني: = الأعمدة المدى { DateSptrs [i] = & stable [i] } صفوف. لأني ، العقيد: = الأعمدة المدى { val: = القيم [i] ب ، موافق: = فال. ([] بايت) واجهة var v {} إذا (موافق) { v = سلسلة (ب) } آخر { v = val } FMT.Println (Col ، V) } } }

في هذا المثال ، يتم استدعاء الصفوف. ثم تطبع الحلقة كل اسم عمود وقيمته المقابلة.

أحدث البرنامج التعليمي أكثر>

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

Copyright© 2022 湘ICP备2022001581号-3