[英]dynamic family tree traverse php javascript
我想创建一个家谱网站,在其中可以通过后端动态添加成员。 我在用php-mvc,mysql。 我通过后端添加成员,我有4个表1.成员-成员的详细信息,还有父亲,母亲的ID; 2个伙伴-显示伙伴关系3个孩子-显示孩子关系4个兄弟姐妹-显示兄弟关系
我的表结构成员
CREATE TABLE IF NOT EXISTS `members` (
`members_id` int(10) NOT NULL AUTO_INCREMENT,
`members_family` int(10) NOT NULL,
`members_first_name` varchar(500) NOT NULL,
`members_sur_name` varchar(500) DEFAULT NULL,
`members_gender` int(10) DEFAULT '0' COMMENT '0-notset,1-male,2-female,3-transgender',
`members_birth_date` date DEFAULT NULL,
`members_is_living` int(10) DEFAULT NULL,
`members_death_date` date NOT NULL DEFAULT '0000-00-00',
`members_email` varchar(1000) DEFAULT NULL,
`members_mobile` varchar(500) DEFAULT NULL,
`members_telephone` varchar(500) DEFAULT NULL,
`members_website` varchar(1000) DEFAULT NULL,
`members_blog` varchar(1000) DEFAULT NULL,
`members_skype` varchar(1000) DEFAULT NULL,
`members_address` varchar(5000) DEFAULT NULL,
`members_birth_place` varchar(1000) DEFAULT NULL,
`members_death_place` varchar(1000) DEFAULT NULL,
`members_profession` varchar(1000) DEFAULT NULL,
`members_company` varchar(1000) DEFAULT NULL,
`members_interests` varchar(5000) DEFAULT NULL,
`members_notes` varchar(1000) DEFAULT NULL,
`members_father` varchar(10) DEFAULT NULL,
`members_mother` int(10) DEFAULT NULL,
`members_generation` int(10) DEFAULT NULL,
`members_status` int(10) NOT NULL,
`members_image` varchar(1000) DEFAULT NULL,
`members_inserttime` datetime NOT NULL,
`members_updatetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`members_id`)
)
伙伴
CREATE TABLE IF NOT EXISTS `partner` (
`partner_id` int(10) NOT NULL AUTO_INCREMENT,
`partner_member` int(10) NOT NULL,
`partner_of_member` int(10) NOT NULL COMMENT 'partner of which member in members_table',
`partner_relation_status` int(10) NOT NULL COMMENT '1-current,2-ex-partner',
`partner_status` int(10) NOT NULL,
`partner_inserttime` datetime NOT NULL,
`partner_updatetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`partner_id`)
)
儿童
CREATE TABLE IF NOT EXISTS `child` (
`child_id` int(10) NOT NULL AUTO_INCREMENT,
`child_member` int(10) NOT NULL,
`child_of_member` int(10) NOT NULL,
`child_status` int(10) NOT NULL,
`child_inserttime` datetime NOT NULL,
`child_updatetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`child_id`)
)
兄弟
CREATE TABLE IF NOT EXISTS `sibling` (
`sibling_id` int(10) NOT NULL AUTO_INCREMENT,
`sibling_member` int(10) NOT NULL,
`sibling_of_member` int(10) NOT NULL COMMENT 'sibling of which member in mebers table',
`sibling_relation` int(10) NOT NULL COMMENT '1-younger,2-elder',
`sibling_status` int(10) NOT NULL,
`sibling_inserttime` datetime NOT NULL,
`sibling_updatetime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`sibling_id`)
)
我正在向该表添加值。 现在,我需要将其显示为树结构。 我没有从搜索中得到任何想法,谁能帮助我像家谱一样遍历数据。
我认为您的表结构不是最佳解决方案。 您应该创建1个表:“ Person”,然后将每个人都放入该表中。 您可以在“人”表中添加一个“角色”字段,以指示该人的“角色”(父亲,母亲,伴侣等)。 有关分层数据的更多信息: http : //mikehillyer.com/articles/managing-hierarchical-data-in-mysql/ 。
如果可以查询数据,则只需将其转换为json树即可。 查看“ jqTree ”以获取有关json树结构的更多信息。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.