{"id":13663149,"url":"https://github.com/KnightNine/ManorDB","last_synced_at":"2025-04-25T13:31:54.667Z","repository":{"id":169607928,"uuid":"256408031","full_name":"KnightNine/ManorDB","owner":"KnightNine","description":"Open Source Database Manager Made in WinForms that copies CastleDB's UI structure. It also has unique features for the purpose of further automating database management.","archived":false,"fork":false,"pushed_at":"2024-04-05T20:28:17.000Z","size":16462,"stargazers_count":25,"open_issues_count":1,"forks_count":2,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-11-10T19:34:18.321Z","etag":null,"topics":["automation","csharp","database","database-generator","database-gui","database-manager","db","game-development","gamedev","json","json-database","net-framework","object-oriented-database","regex","spreadsheets","winforms"],"latest_commit_sha":null,"homepage":"","language":"C#","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/KnightNine.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-04-17T05:18:40.000Z","updated_at":"2024-11-01T15:16:29.000Z","dependencies_parsed_at":"2024-03-30T22:23:22.713Z","dependency_job_id":"007ae039-c621-46fb-ad26-32df15cb93de","html_url":"https://github.com/KnightNine/ManorDB","commit_stats":null,"previous_names":["knightnine/manordb"],"tags_count":40,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/KnightNine%2FManorDB","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/KnightNine%2FManorDB/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/KnightNine%2FManorDB/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/KnightNine%2FManorDB/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/KnightNine","download_url":"https://codeload.github.com/KnightNine/ManorDB/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":250824999,"owners_count":21493376,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["automation","csharp","database","database-generator","database-gui","database-manager","db","game-development","gamedev","json","json-database","net-framework","object-oriented-database","regex","spreadsheets","winforms"],"created_at":"2024-08-02T05:02:19.174Z","updated_at":"2025-04-25T13:31:49.654Z","avatar_url":"https://github.com/KnightNine.png","language":"C#","readme":"\u003ccenter\u003e\u003cimg src=\"https://raw.githubusercontent.com/KnightNine/ManorDB/master/Images/logowback.png\" alt=\"Logo\" width=\"400\" \u003e \u003c/center\u003e\n\u003chr\u003e\n\u003cp\u003e\nOpen Source Json Database Manager Made in WinForms that copies \u003ca href = \"https://github.com/ncannasse/castle\"\u003eCastleDB's\u003c/a\u003e UI structure. \nThis Database Manager also has features which are unique to it for the purpose of further automating database management, features like: adding additional restrictions to how data can be entered, automatically constructed tables defined via \"table scripts\", and referencing data from non-database files via regex.\n\u003c/p\u003e\n\n\u003ch2\u003eWhat it looks like :\u003c/h2\u003e\n\u003ccenter\u003e\u003cimg src=\"https://raw.githubusercontent.com/KnightNine/ManorDB/master/Images/darkmode.PNG\" alt=\"Logo\" width=\"900\" \u003e \u003c/center\u003e\n\n\n\u003cp\u003e\n\u003cb\u003eQ:\u003c/b\u003e Why did I create this when CastleDB already exists?\n\u003c/p\u003e\n\u003cp\u003e\n\u003cb\u003eA:\u003c/b\u003e Because CastleDB has/had bugs that creep in when the database reaches a certain level of complexity which made the 3000 line json file I had unreadable at seemingly random, happened 3 times before I decided not to stick around and find out what the exact issue was and just make my own DB manager that actually works. And so I won't have to sift through 3000 lines of json script to fix the issue as there is no indication of what line the read error occurred at.\n\nThe game I am working on relies on complex repeating data structures to define its entities therefore I find that this Database manager would be particularly useful to me.\n\u003c/p\u003e\n\n\n\n\u003chr\u003e\n\u003ch2\u003eGoals/Nice-to-Haves:\u003c/h2\u003e\n\u003cp\u003e\n  There are some features that should be added beyond basic functionality but my attention is needed elsewhere. Here is what MDB is lacking in order of most prioritized to least:\n\u003cp/\u003e\n\u003cul\u003e\n  \u003cli\u003eability to change columns linked to a `Auto Table Constructor Script Receiver` column without having to delete and re-add the column (thus losing data)\u003c/li\u003e\n  \u003cli\u003ehovering over the table tabs should allow you to scroll through them with the scroll wheel\u003c/li\u003e\n  \u003cli\u003eColumn Type Icons (to show the type of each column)\u003c/li\u003e\n  \u003cli\u003e make the row being hovered over become more visible  \u003c/li\u003e\n  \u003cli\u003eSearch functionality for key reference dropdowns\u003c/li\u003e\n  \u003cli\u003eEditable \"on Mouse Hover\" Column Descriptions + text editor for text cells\u003c/li\u003e\n  \u003cli\u003e\"Table Directory\" column type that constructs and stores a string array of the directory in another table's structure, this would resolve the typos that could arise from writing these directories manually.\u003c/li\u003e\n  \u003cli\u003eKey Shortcuts\u003c/li\u003e\n  \u003cli\u003eImage Columns\u003c/li\u003e\n  \u003cli\u003eFile Directory Primary Key List Table Type (a table that refrences a file directory and generates a table with the file names as row data for a Primary Key column.)\u003c/li\u003e\n  \u003cli\u003eUndo/Redo\u003c/li\u003e\n  \u003cli\u003ean option to expand all rows so that text is readable\u003c/li\u003e\n  \u003cli\u003e Normalized Numeric Column (all values are restricted to total 1 across all rows in the same table/sub-table)\u003c/li\u003e\n  \u003cli\u003eA \"Foreign Key Refrence Primary Key\" column (to base a table around foreign keys that can't have duplicate refrences)\u003c/li\u003e\n  \u003cli\u003eA \"force adjecent cell to value when cell is filled\" setting, similar to the feature that disallows two cells from being filled at the same time, except instead of disabling the other cell entirely, the cell is set to a specific value and becomes read only. \u003c/li\u003e\n  \u003cli\u003eTable Shifting (re-ordering of Tables)\u003c/li\u003e\n  \u003cli\u003eFurther Organization of Code (in progress)\u003c/li\u003e\n  \u003cli\u003eDetailed Commentation (in progress)\u003c/li\u003e\n  \u003cli\u003eExport to Index Removal (removal of indexes that store the order of rows in the dictionary and replacing them with that row's primary key, in order to further simplify data)\u003c/li\u003e\n  \u003cli\u003eSeparators (equivalent to CDB's \"separator\")\u003c/li\u003e\n  \u003cli\u003eColumn Input Limiter (An option to limit the number of rows that can be filled within a certain column before the rest become disabled)\u003c/li\u003e\n \n \n\u003c/ul\u003e\n\n\n\u003ch2\u003eDocumentation:\u003c/h2\u003e\n\u003ca href= \"https://github.com/KnightNine/ManorDB/wiki\"\u003e Check out the wiki for more info! \u003c/a\u003e\n\n","funding_links":[],"categories":["C\\#"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FKnightNine%2FManorDB","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FKnightNine%2FManorDB","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FKnightNine%2FManorDB/lists"}