首頁  >  問答  >  主體

如何在SQL查詢中動態產生表名?

<p>我有一個 SQL 查詢,它使用 MySQL 資料庫從中取得資訊。表名稱是第一個常數,末尾帶有不同的 IMEI 編號。 </p> <p>gs_object_data_12345678</p> <p>12345678 在我的腳本中被標識為 <code>$_GET</code> 但當我嘗試更改表名稱時,它不會顯示該表中的資料</p> <pre class="brush:php;toolbar:false;">$imei = $_GET['imei']; $result = $db->query("SELECT * FROM gs_object_data_'$imei' LIMIT 200 ");</pre> <p>如果我使用下面的字串,它就可以工作</p> <pre class="brush:php;toolbar:false;">$result = $db->query("SELECT * FROM gs_object_data_12345678 LIMIT 200 ");</pre> <p>我需要用<code>$_GET</code>訊息更改表名</p> <p>URL <code>alarm_action.php?id=58543®=****&imei=862202228007105</code> 中包含 IMEI,因此資訊應該可以透過</p>
P粉588152636P粉588152636434 天前494

全部回覆(1)我來回復

  • P粉232793765

    P粉2327937652023-09-04 10:39:04

    像這樣使用

    $imei = $_GET['imei'];
    $result = $db->query("SELECT * FROM gs_object_data_" . $imei . " LIMIT 200 ");

    $result = $db->query("SELECT * FROM gs_object_data_{$imei} LIMIT 200 ");

    以受保護的方式

    $imei = $_GET['imei'];
    
    $stmt = $db->prepare("SELECT * FROM gs_object_data_? LIMIT 200");
    $stmt->bind_param("s", $imei);
    $stmt->execute();
    
    $result = $stmt->get_result();

    回覆
    0
  • 取消回覆