'频道id'必须为数字", "-1"); exit(); } if (preg_match("#[^a-z0-9]#i", $nid) || $nid == "") { ShowMsg("'频道名字标识'必须为英文字母或与数字混合字符串", "-1"); exit(); } if ($addtable == "") { ShowMsg("附加表不能为空", "-1"); exit(); } $trueTable2 = str_replace("#@__", $cfg_dbprefix, $addtable); if ($issystem == -1 && $id > 0) $id = $id * -1; //检查id是否重复 $row = $dsql->GetOne("SELECT * FROM #@__channeltype WHERE id='$id' OR nid LIKE '$nid' OR addtable LIKE '$addtable'"); if (is_array($row)) { ShowMsg("可能‘频道id’、‘频道名称标识’、‘附加表名称’在数据库已存在,不能重复使用", "-1"); exit(); } $mysql_version = $dsql->GetVersion(); //创建附加表 if ($trueTable2 != '') { $istb = $dsql->IsTable($trueTable2); if (!$istb || $isdel == 1) { //是否需要摘要字段 $dsql->ExecuteNoneQuery("DROP TABLE IF EXISTS `{$trueTable2}`;"); if ($issystem != -1) { $tabsql = "CREATE TABLE `$trueTable2`( `aid` int(11) NOT NULL default '0', `typeid` int(11) NOT NULL default '0', `redirecturl` varchar(255) NOT NULL default '', `templet` varchar(30) NOT NULL default '', `userip` char(15) NOT NULL default '', "; } else { $tabsql = "CREATE TABLE `$trueTable2`( `aid` int(11) NOT NULL default '0', `typeid` int(11) NOT NULL default '0', `channel` SMALLINT NOT NULL DEFAULT '0', `arcrank` SMALLINT NOT NULL DEFAULT '0', `mid` MEDIUMINT( 8 ) UNSIGNED NOT NULL DEFAULT '0', `click` INT( 10 ) UNSIGNED NOT NULL DEFAULT '0', `title` varchar(60) NOT NULL default '', `senddate` int(11) NOT NULL default '0', `flag` set('c','h','p','f','s','j','a','b') default NULL, `litpic` varchar(60) NOT NULL default '', `userip` char(15) NOT NULL default '', `lastpost` INT( 10 ) UNSIGNED NOT NULL DEFAULT '0', `scores` MEDIUMINT( 8 ) NOT NULL DEFAULT '0', `goodpost` MEDIUMINT( 8 ) UNSIGNED NOT NULL DEFAULT '0', `badpost` MEDIUMINT( 8 ) UNSIGNED NOT NULL DEFAULT '0', "; } if ($mysql_version < 4.1) { $tabsql .= " PRIMARY KEY (`aid`), KEY `typeid` (`typeid`)\r\n) TYPE=MyISAM; "; } else { $tabsql .= " PRIMARY KEY (`aid`), KEY `typeid` (`typeid`)\r\n) ENGINE=MyISAM DEFAULT CHARSET=".$cfg_db_language."; "; } $rs = $dsql->ExecuteNoneQuery($tabsql); if (!$rs) { ShowMsg("创建附加表失败!".$dsql->GetError(), "javascript:;"); exit(); } } } $listfields = $fieldset = ''; if ($issystem == -1) { $fieldset = " \r\n"; $listfields = 'channel,arcrank,mid,click,title,senddate,flag,listpic,lastpost,scores,goodpost,badpost'; } $inQuery = "INSERT INTO `#@__channeltype`(id,nid,typename,addtable,addcon,mancon,editcon,useraddcon,usermancon,usereditcon,fieldset,listfields,issystem,issend,arcsta,usertype,sendrank,needdes,needpic,titlename,onlyone,dfcid) VALUES ('$id','$nid','$typename','$addtable','$addcon','$mancon','$editcon','$useraddcon','$usermancon','$usereditcon','$fieldset','$listfields','$issystem','$issend','$arcsta','$usertype','$sendrank','$needdes','$needpic','$titlename','$onlyone','$dfcid');"; $dsql->ExecuteNoneQuery($inQuery); ShowMsg("成功增加一个频道模型", "mychannel_edit.php?id=".$id); exit(); } $row = $dsql->GetOne("SELECT id FROM `#@__channeltype` ORDER BY id DESC LIMIT 0,1 "); $newid = $row['id'] + 1; if ($newid < 10) $newid = $newid + 10; require_once(DEDEADMIN."/templets/mychannel_add.htm");