有沒有辦法構建類似於 DOMDocument 構建 HTML 文檔的 SQL 查詢? (Is there a way to build SQL queries similar to how DOMDocument builds HTML document?)


問題描述

有沒有辦法構建類似於 DOMDocument 構建 HTML 文檔的 SQL 查詢? (Is there a way to build SQL queries similar to how DOMDocument builds HTML document?)

有沒有辦法為 HTML 頁面構建類似於 DOMDocument 的 SQL 查詢?

這裡出現語法錯誤的可能性太多:

$query = "SELECT " . $fields . " FROM " . $table;
if ($condition) 
  $query .= "WHERE status > 1";

是否有第三方或庫存方式來構建類似於 DOMDocument 的查詢?


參考解法

方法 1:

When using plain sql queries I usually don't use multi‑line concats as they lead to a syntax error as you have above. When adding multiple lines for one part, I place the connector (comma for field lists, join for from, and/or for where) at the beginning of the new line.

$query = "SELECT ".$fields;
$query .= " FROM ".$table;
if ($condition) {
  $query .= "WHERE status > 1";
}

For some parts using arrays with join() comes in handy:

$conditions = array();
$conditions[] = "status > 1";
// Later on
if ($conditions) {
  // Depending on your intention, you can use AND or OR here:
  $query .= "WHERE ".join(' AND ', $conditions);
}

But there are many libraries to build queries in an object oriented manner. Last I tested is doctrine's query builder.

(by Roman Toasovclemens321)

參考文件

  1. Is there a way to build SQL queries similar to how DOMDocument builds HTML document? (CC BY‑SA 2.5/3.0/4.0)

#domdocument #SQL #MySQL #PHP






相關問題

PHP/DOMDocument: unset() 不釋放資源 (PHP/DOMDocument: unset() does not release resources)

C++ Xerces Parser 加載 HTML 並蒐索 HTML 元素 (C++ Xerces Parser Load HTML and Search for HTML Elements)

Cách lấy tên thuộc tính kiểu bằng PHP xpath (How to get the style property name using PHP xpath)

DOMDocument:如何解析類似 bbcode 的標籤? (DOMDocument : how to parse a bbcode like tag?)

如何使用 DOMDocument 獲取此 html 中的 url (How to use DOMDocument to get url in this html)

DomDocument 未能為 RSS 提要添加“鏈接”元素 (DomDocument failing to add a "link" element for RSS feed)

如何防止將文檔類型添加到 HTML 中? (How to prevent the doctype from being added to the HTML?)

PHP DOM 文檔回顯問題 (PHP DOMdocument echoing problem)

使用 PHP 將數據放到服務器上(新的 DOMdocument 不起作用) (Use PHP to put data onto server ( new DOMdocument not working))

有沒有辦法構建類似於 DOMDocument 構建 HTML 文檔的 SQL 查詢? (Is there a way to build SQL queries similar to how DOMDocument builds HTML document?)

來自 URL 的 file_get_contents 僅適用於本地服務器 (file_get_contents from URL works on local server only)

使用多個 <table> 標記抓取 HTML 頁面並從特定的 <a> 標記後代中提取文本 (Scrape HTML page with multiple <table> tags and extract text from specific <a> tag descendants)







留言討論