dongmoyu0336 2014-04-11 11:05
浏览 78
已采纳

如何在mysql for Wordpress数据库中将行值转换为列标题

Using the following query I have fetched results from wp_posts and wp_postmeta table.

SELECT a., b. FROM wp_posts a, wp_postmeta b WHERE a.ID = b.post_id AND a.post_status = 'publish' AND a.post_type='wpsc-product'

From the above result, I want to filter the results to one more stage

As you know wp_postmeta structure is like

meta_id | post_id | meta_key | meta_value

I want to make all the meta_key values of the result to column names and its corresponding value as its value.

For eg if the table is like:

Meta_id-----------post_id-----------meta_key-----------meta_value

1-----------------31--------------mk1----------------mv1

2-----------------31--------------mk2----------------mv2

3-----------------31--------------mk3----------------mv3

The expected result is:

Meta_id-----------post_id-----------mk1--------mk2---------mk3

1-----------------31-----------------mv1---------mv2---------mv3

Is this possible??? I want this along with my join query.

The formatting of question is not correct. Please forgive for that.

  • 写回答

2条回答 默认 最新

  • douzhe3516 2014-04-11 11:17
    关注

    You can use CASE if there are limited meta_keys

    SELECT a.*,b.Meta_id, b.post_id,
    CASE WHEN b.meta_key ='mk1' THEN b.meta_value END `mk1`,
    CASE WHEN b.meta_key ='mk2' THEN b.meta_value END `mk2`,
    CASE WHEN b.meta_key ='mk3' THEN b.meta_value END `mk3`
    FROM wp_posts a
    JOIN wp_postmeta b ON( a.ID = b.post_id )
    WHERE a.post_status = 'publish' 
    AND a.post_type='wpsc-product'
    AND b.meta_key IN('mk1','mk2','mk3')
    

    Edit for duplicates issue you can use JOINs

    SELECT p.*,
    a.Meta_id, 
    a.post_id,
    a.meta_value mk1, 
    b.meta_value mk2,
    c.meta_value mk3
    FROM wp_posts p  
    LEFT JOIN  wp_postmeta a ON(p.ID =a.post_id)
    JOIN  wp_postmeta b USING(post_id) /* is equal to ON(b.post_id = a.post_id) */
    JOIN  wp_postmeta c USING(post_id)
    WHERE a.meta_key = 'mk1'
    AND b.meta_key = 'mk2'
    AND c.meta_key='mk3'
    

    Fiddle Demo only for meta table

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 three.js添加后处理以后模型锯齿化严重