php - 获取英文版的所有产品 - WooCommerce 和 WPML

标签 php mysql woocommerce wpml

我正在开发一个与 WordPress 数据库配合使用的 Web 应用程序。在我的网站(与 WooCommerce 和 WPML 配合使用)中,我有两种语言的产品 - 英语(第一)、塞尔维亚语(第二)。我编写了一个 SQL 代码,从数据库获取产品及其常规价格和促销价格等,但我只想获取 lang = en 的产品(英文版的产品)。问题是我不知道如何获得它们。

简单的 SQL:

$sql = 'SELECT * from `wp_posts` WHERE post_type = product';


这是从数据库中选择的方法:

// SELECT
public function select (
            $table_1 = ' wp_posts ', 
            $table_2 = ' wp_postmeta ', 
            $rows = ' t1.id, t1.post_title, guid, post_type ', 
            $where = ' t1.post_status = "publish" AND t1.post_type = "product" OR t1.post_type = "product_variation" ', 
            $groupby = ' t1.ID, t1.post_title '
        ) {

    // Connect to database and set charset
    $this->connect();
    $this->conn->set_charset('utf8');


    // Published products
    $sql = "SELECT $rows,
            max(case when meta_key = '_regular_price' then t2.meta_value end) AS price, 
            max(case when meta_key = '_sale_price' then t2.meta_value end) AS sale,
            max(case when meta_key = 'attribute_colors' then t2.meta_value end) AS colors,
            max(case when meta_key = 'attribute_number' then t2.meta_value end)
            FROM $table_1 AS t1
            INNER JOIN $table_2 AS t2 ON ( t1.ID = t2.post_id ) 
            WHERE $where
            GROUP BY $groupby";

    $result = mysqli_query($this->conn, $sql);
    $published_products_count = mysqli_num_rows($result);



    // Trashed products
    $trashed_sql = "SELECT post_status FROM `wp_posts`
                    WHERE post_status = 'trash'";

    $trashed_result = mysqli_query($this->conn, $trashed_sql);
    $trashed_products_count = mysqli_num_rows($trashed_result);


    // If results -> show them
    if ($result) {

        printf( "\t\t" . "<p>There are <strong>%d published</strong> products and <strong>%d trashed</strong>.</p>", $published_products_count, $trashed_products_count);

    $table = '
    <table class="pure-table pure-table-bordered">
        <thead>
            <tr>
                <th>Row. №</th>
                <th>ID</th>
                <th>Product</th>
                <th>Regular price</th>
                <th>Sale price</th>
                <th>Type</th>
                <th>Edit</th>
            </tr>
        </thead>';

        $row_number = 1;

        while ($row = $result->fetch_assoc()) {

            $table .= '
            <tr>
                <td>' . $row_number++ . '</td>
                <td>' . $row["id"] . '</td>
                <td><a href="http://www.enroll.rs/wp-admin/post.php?post=' . $row["id"] . '&action=edit" target="_blank">' . $row["post_title"] . '</a></td>
                <td class="price">' . $row["price"] . '</td>
                <td class="sale">' . $row["sale"] . '</td>
                <td>' . $row["post_type"] . '</td>
                <td><a href="edit_form.php?id=' . $row["id"] . '">Edit</a></td>
            </tr>';
        }

    $table .= '
    </table>';

        echo $table;
    }

    // If no results
    else {
        echo 'There isn't any products';
    }
}

希望有人能帮助我!

提前致谢! :)

附注该应用程序不是基于 WordPress!

最佳答案

WPML 插件创建了几个新表来管理多语言,而不影响标准 WP 帖子表。具体来说,它创建 wp_icl_translations 表,在其中存储帖子和语言之间的关系。

您需要向查询添加两个新的 JOIN 语句:

JOIN wp_icl_translations t ON wp_posts.ID = t.element_id AND t.element_type = 'post_product' JOIN wp_icl_languages l ON t.language_code=l.code AND l.active=1

然后,您可以向 WHERE 语句添加一个新条件,如下所示:

AND t.language_code='en'

希望这有帮助。 问候。

关于php - 获取英文版的所有产品 - WooCommerce 和 WPML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26425192/

相关文章:

php - 根据两列列出表

python - 执行许多插入重复键更新错误: Not all parameters were used

php - SQL - 如果存在 - 选择 A - 否则 - 选择 B

php - 如何在 Wordpress 导航菜单中自动添加类别和子类别

php - 如何将 HTML 添加到 WooCommerce 结帐时的 "billing_email"字段?

javascript - 如何从输入字段中获取特定值

php - 如何在服务器端处理模式下使用 JOIN 进行数据库查询

php - 与 2 个表的特定 JOIN

php - mysql 在更新时触发问题

php - 获取 WooCommerce 产品属性标签名称