דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. node - npm-mssql - es6 - כיצד לבצע שאילתא עם משתנים

node - npm-mssql - es6 - כיצד לבצע שאילתא עם משתנים

מתוזמן נעוץ נעול הועבר תכנות
2 פוסטים 2 כותבים 103 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • M מנותק
    M מנותק
    mekev
    כתב ב נערך לאחרונה על ידי mekev
    #1

    אני משתמש בחבילת mssql
    ע"מ להמנע מהזרקות sql
    אני משתמש באפשרות המובנת של es6

    אני מעוניין לבצע שאילתא שסעיף הselect קבוע
    והwhere משתנה לפי req.query

    הבעיה היא

    1. שכתוב שם
      Column names cannot be passed/set in statements using variables.
    2. שאני בכ"ז רוצה לכתוב את הselect רק פעם אחת

    דוגמא:

     router.get('/all_users', (req, res) => {
    
            let ids = req.query;
    
            if (ids) {
                const idList = ids.split(',').map(id => `'${id.trim()}'`).join(',');
                ids = ` and id_user in (${idList})`;
            }
    
            sql.connect(Config).then(pool => {
                return pool.request().query`
                select *
                from users
                where active = 1  ${ids}`;
            }).then(result => {
                res.send(result.recordset);
            }).catch(err => {
                console.error(err);
                res.status(500).send(err.message);
            });
        });
    
    תגובה 1 תגובה אחרונה
    0
    • dovidD מנותק
      dovidD מנותק
      dovid ניהול
      כתב ב נערך לאחרונה על ידי dovid
      #2

      במקרה כזה אתה חייב להשתמש בפרמטרים במפורש (שזה הדרך הרגילה טרום הES6 Tag Function)

      router.get('/all_users', (req, res) => {
              const sql = "select * from users where active = 1"
              sql.connect(Config).then(pool => {
              const request = pool.request();
              if(req.query){
                  request.input('idList', sql.VarChar, req.query.split(',').map(id => Number(id)).join(','));
                  sql += "and id_user in (@idList)";
              }
              return request.query(sql);
          }).then(result => {
              res.send(result.recordset);
          }).catch(err => {
              console.error(err);
              res.status(500).send(err.message);
          });
      });
      

      הTrim שעשית מיותר כי ברשימת in מותר שיהיו רווחים.
      מאידך שמתי Number שמוודא שמדובר במספר, הוא על הדרך גם עושה Trim שהרי הוא מביא מספר גם למספר עם רווחים.

      מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

      בכל נושא אפשר ליצור קשר dovid@tchumim.com

      תגובה 1 תגובה אחרונה
      3

      בא תתחבר לדף היומי!
      • התחברות

      • אין לך חשבון עדיין? הרשמה

      • התחברו או הירשמו כדי לחפש.
      • פוסט ראשון
        פוסט אחרון
      0
      • דף הבית
      • קטגוריות
      • פוסטים אחרונים
      • משתמשים
      • חיפוש
      • חוקי הפורום