以下为表结构

  1. ad_position 广告位
position_idtinyint(3)否/广告位自增id
position_namevarchar(60)否/广告位名称
ad_widthsmallint(5)否/0广告位宽度
ad_heightsmallint(5)否/0广告高度
position_descvarchar(255)否/广告位描述
position_styletext否/广告位模板代码
CREATE TABLE `ecs_ad_position` (
`position_id` tinyint(3) unsigned NOT NULL AUTO_INCREMENT,
  `position_name` varchar(60) NOT NULL DEFAULT '',
  `ad_width` smallint(5) unsigned NOT NULL DEFAULT '0',
  `ad_height` smallint(5) unsigned NOT NULL DEFAULT '0',
  `position_desc` varchar(255) NOT NULL DEFAULT '',
  `position_style` text NOT NULL,
  PRIMARY KEY (`position_id`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
  1. ad 广告表
ad_idsmallint(5)否/自增ID号
position_idsmallint(5)否/00,站外广告;从1开始代表的是该广告所处的广告位,同表ad_postition中的字段position_id的值
media_typetinyint(3)否/0广告类型,0图片;1flash;2代码3文字
ad_namevarchar(60)否/该条广告记录的广告名称
ad_linkvarchar(255)否/广告链接地址
ad_codetext否/广告链接的表现,文字广告就是文字或图片和flash就是它们的地址
start_timeint(11)否/0广告开始时间
end_timeint(11)否/0广告结速时间
link_manvarchar(60)否/广告联系人
link_emailvarchar(60)否/广告联系人的邮箱
link_phonevarchar(60)否/广告联系人的电话
click_countmediumint(8)否/0该广告点击数
enabledtinyint(3)否/1该广告是否关闭;1开启;0关闭;关闭后广告将不再有效
CREATE TABLE `ecs_ad` (
  `ad_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
  `position_id` smallint(5) unsigned NOT NULL DEFAULT '0',
  `media_type` tinyint(3) unsigned NOT NULL DEFAULT '0',
  `ad_name` varchar(60) NOT NULL DEFAULT '',
  `ad_link` varchar(255) NOT NULL DEFAULT '',
  `ad_code` text NOT NULL,
  `start_time` int(11) NOT NULL DEFAULT '0',
  `end_time` int(11) NOT NULL DEFAULT '0',
  `link_man` varchar(60) NOT NULL DEFAULT '',
  `link_email` varchar(60) NOT NULL DEFAULT '',
  `link_phone` varchar(60) NOT NULL DEFAULT '',
  `click_count` mediumint(8) unsigned NOT NULL DEFAULT '0',
  `enabled` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '显示',
  PRIMARY KEY (`ad_id`),
  KEY `position_id` (`position_id`),
  KEY `enabled` (`enabled`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

php代码 Thinkphp 3.2实现

/**
 * 获取广告位中的广告
 * @param $position 广告位
 * @param int $num 广告数量
 * @return mixed    广告列表
 */
function getAdList($position, $num = 1)
{
    // $where = array('id' => $position, );
    //$adPosition = M("AdvertisingPosition")->where($where)->getField('advertising_id');
    //$map['position'] = array('eq',$adPosition);
    $map['position'] = array('eq', $position);
    $map['start_time'] = array('lt', time());
    $map['end_time'] = array('gt', time());
    $ad_list = M("Advertising")->where($map)->limit($num)->order('sort desc')->select();
    return $ad_list;
}
01-10 07:58
查看更多