dps57553 2016-03-13 09:25
浏览 45
已采纳

jQuery nestable - 使用PHP嵌套集模型保存到MySQL [关闭]

I use now Nestable plugin for eshop categories http://dbushell.github.io/Nestable/

I save data to MySQL database with columns parent_id, order, level using the Nested Set model.

But I would like to use nested model only with columns lft, rgt

Could you please gave me example how to save data to database or is there any wrapper which can I use to just insert new item, update all tree and delete one item, using the Nested Set model?


I found Baobab library http://www.sideralis.org/baobab/, which do these operations, but it's very heavy.

  • 写回答

1条回答 默认 最新

  • douji7399 2016-03-13 15:35
    关注

    Here...

    To Insert:

    begin;
    SELECT rgt INTO new_lft FROM tree_map WHERE node_id = parent_id;
    UPDATE tree_map SET rgt = rgt + 2 WHERE rgt >= new_lft;
    UPDATE tree_map SET lft = lft + 2 WHERE lft > new_lft;
    INSERT INTO tree_map (lft, rgt, parent_id) VALUES (new_lft, (new_lft + 1), parent_id);
    commit;
    SELECT LAST_INSERT_ID();
    

    To delete:

    SELECT lft, rgt, (rgt - lft), (rgt - lft + 1), parent_id 
      INTO new_lft, new_rgt, has_leafs, width, superior_parent 
      FROM tree_map WHERE node_id = pnode_id;
    
    begin;
    DELETE FROM tree_content WHERE node_id = pnode_id;
    
    IF (has_leafs = 1) THEN
      DELETE FROM tree_map WHERE lft BETWEEN new_lft AND new_rgt;
      UPDATE tree_map SET rgt = rgt - width WHERE rgt > new_rgt;
      UPDATE tree_map SET lft = lft - width WHERE lft > new_rgt;
    ELSE
      DELETE FROM tree_map WHERE lft = new_lft;
      UPDATE tree_map SET rgt = rgt - 1, lft = lft - 1, parent_id = superior_parent 
       WHERE lft BETWEEN new_lft AND new_rgt;
      UPDATE tree_map SET rgt = rgt - 2 WHERE rgt > new_rgt;
      UPDATE tree_map SET lft = lft - 2 WHERE lft > new_rgt;
    END IF;
    commit;
    

    You might also want to use amazing stored procedure for MySQL instead:

    https://github.com/werc/TreeTraversal/blob/master/sql/r_tree_traversal.sql#L4

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
  • ¥100 连续两帧图像高速减法
  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)