- Create a database called TreeTest and open QA and execute Setup SQL
- Now you are ready to go. Simply select the test you with to run, then
copy the code below, paste it into Query Analyser and hit F5!
data:image/s3,"s3://crabby-images/36e3d/36e3dae76f5a10fb4106b5d15e0f54c9bd03ed04" alt="Schema"
- TEST 1 - _NestedSet_ConvertToAdjacency
- TEST 2 - _NestedSet_DeleteAndClose
- TEST 3 - _NestedSet_DeleteNodeAndLeafs
- TEST 4 - _NestedSet_GetAll
- TEST 5 - _NestedSet_GetDepthFullTree
- TEST 6 - _NestedSet_GetDepthSubTree
- TEST 7 - _NestedSet_GetLeafs
- TEST 8 - _NestedSet_GetNextLevel
- TEST 9 - _NestedSet_GetSinglePath
- TEST 10 - _NestedSet_GetTree
- TEST 11 - _NestedSet_GetTree
- TEST 12 - _NestedSet_InsertOnSameLevel
- TEST 13 - _NestedSet_Move
- TEST 14 - _NestedSet_MoveUpDown
Top
Test 1 - _NestedSet_ConvertToAdjacency
Converts a nested set to a Adjacency model
exec __Reset exec _NestedSet_ConvertToAdjacency
data:image/s3,"s3://crabby-images/4f71c/4f71cecd48bdaf24b2adc1ea139220a1f52b61ab" alt="Test1"
Top
Test 2 - _NestedSet_DeleteAndClose
Deletes a node then moves any sub nodes up to close the gap
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_DeleteAndClose 7 exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/b6a66/b6a6642edcfd9ad134768b2215a7b9a564312aef" alt="Test3"
Top
Test 3 - _NestedSet_DeleteNodeAndLeafs
Deletes a node and all sub nodes then closes any gaps
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_DeleteNodeAndLeafs 2 exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/e07ad/e07ad98e5b187dd3f438de084e4d273819510517" alt="Test3"
Top
Test 4 - _NestedSet_GetAll
Simply gets all the nodes
exec __Reset exec _NestedSet_GetAll
data:image/s3,"s3://crabby-images/a9d9b/a9d9b10caf361f352315d774d5fc824a271ab953" alt="Test4"
Top
Test 5 - _NestedSet_GetDepthFullTree
Simply gets all the nodes with depths
exec __Reset exec _NestedSet_GetDepthFullTree
data:image/s3,"s3://crabby-images/0b966/0b966df8a65bcaf87efb61e88c5bbb76c2afc910" alt="Test5"
Top
Test 6 - _NestedSet_GetDepthSubTree
Gets the depths of the selected node and sub nodes
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_GetDepthSubTree 2
data:image/s3,"s3://crabby-images/f6186/f61866febbc0409ac7a84f1f988b04b727fca2a7" alt="Test6"
Top
Test 7 - _NestedSet_GetLeafs
Gets all the leafs - that is nodes without sub nodes
exec __Reset exec _NestedSet_GetLeafs
data:image/s3,"s3://crabby-images/36e30/36e3090800fe40b4f9f47edb575bd42b936e44fd" alt="Test7"
Top
Test 8 - _NestedSet_GetNextLevel
Gets all nodes that are directly below the selected node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_GetNextLevel 1
data:image/s3,"s3://crabby-images/6eb39/6eb39027cb815ae01695f3399516348e4ca25b6a" alt="Test8"
Top
Test 9 - _NestedSet_GetSinglePath
Gets a full path for a single node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_GetSinglePath 8
data:image/s3,"s3://crabby-images/98400/98400cd58f86d6f030dce8545c4fceeb8dc1ba89" alt="Test9"
Top
Test 10 - _NestedSet_GetTree
Gets nodes including and below the selected node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_GetTree 2
data:image/s3,"s3://crabby-images/1b8ff/1b8ff4b1c30a7713669241bd51a8b2fd56c42cd7" alt="Test10"
Top
Test 11 - _NestedSet_InsertDirectlyBelow
Inserts a node directly below the selected node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_InsertDirectlyBelow 1,'new name' exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/772d2/772d2df87866dfc52aa1ffdb82d824c8e70aabb3" alt="Test11"
Top
Test 12 - _NestedSet_InsertOnSameLevel
Inserts a node on the same level (at the bottom) as the selected node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_InsertOnSameLevel 1,'new name' exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/f0333/f03337d911c658707d9b4e5eebc4aba74ae5f4d4" alt="Test12"
Top
Test 13 - _NestedSet_Move
Moves a node to below another node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_Move 6,3 exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/00d79/00d791938825265a03d41ac663ee9e2f6fb3f3f1" alt="Test13"
Top
Test 14 - _NestedSet_MoveUpDown
Moves a node on the same level either up or down (1 for up, 0 for down) to another node
exec __Reset exec _NestedSet_TestLayout exec _NestedSet_MoveUpDown 2,0 exec _NestedSet_TestLayout
data:image/s3,"s3://crabby-images/db916/db9161314217b1b499797de8fe81d1fe6bd6b945" alt="Test14"
References
- Mike Hillyer Managing Hierarchical Data in MySQL (I have used his sample data)
- Joe Celko's Trees and Hierarchies in SQL for Smarties - 2004
Alejandro Izaguirre Google groups
I would also like to thank:-
- Ryan O'Neill
- Nick Crowther
AMAZING!! LOVE IT! Thank you.
ReplyDelete