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 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)