php在表中添加新字段,Typecho文章表添加新字段

1.首先数据表 typecho_contents 中新建一个test_url字段,类型可为字符串。

2.后台模板文件write-post.php 表单中插入:

test_url(); ?>"/>

3.在 WidgetContentsPostEdit.php 这里的 writePost 函数里需要接收新字段参数:public function writePost()

{

$contents = $this->request->from('password', 'allowComment',

'allowPing', 'allowFeed', 'slug', 'tags', 'text', 'visibility','test_url');

4.1 WidgetAbstractContents.php 这里的 insert 函数添加新参数:/**

* 插入内容

*

* @access public

* @param array $content 内容数组

* @return integer

*/

public function insert(array $content)

{

/** 构建插入结构 */

$insertStruct = array(

'title' => empty($content['title']) ? NULL : htmlspecialchars($content['title']),

'created' => empty($content['created']) ? $this->options->gmtTime : $content['created'],

'modified' => $this->options->gmtTime,

'text' => empty($content['text']) ? NULL : $content['text'],

'order' => empty($content['order']) ? 0 : intval($content['order']),

'authorId' => isset($content['authorId']) ? $content['authorId'] : $this->user->uid,

'template' => empty($content['template']) ? NULL : $content['template'],

'type' => empty($content['type']) ? 'post' : $content['type'],

'status' => empty($content['status']) ? 'publish' : $content['status'],

'password' => empty($content['password']) ? NULL : $content['password'],

'commentsNum' => empty($content['commentsNum']) ? 0 : $content['commentsNum'],

'allowComment' => !empty($content['allowComment']) && 1 == $content['allowComment'] ? 1 : 0,

'allowPing' => !empty($content['allowPing']) && 1 == $content['allowPing'] ? 1 : 0,

'allowFeed' => !empty($content['allowFeed']) && 1 == $content['allowFeed'] ? 1 : 0,

'parent' => empty($content['parent']) ? 0 : intval($content['parent']),

'test_url' => empty($content['test_url']) ? NULL : $content['test_url']

);

4.2 这里的update函数里构建更新结构加入新字段:/**

* 更新内容

*

* @access public

* @param array $content 内容数组

* @param Typecho_Db_Query $condition 更新条件

* @return integer

*/

public function update(array $content, Typecho_Db_Query $condition)

{

/** 首先验证写入权限 */

if (!$this->isWriteable(clone $condition)) {

return false;

}

/** 构建更新结构 */

$preUpdateStruct = array(

'title' => empty($content['title']) ? NULL : htmlspecialchars($content['title']),

'order' => empty($content['order']) ? 0 : intval($content['order']),

'text' => empty($content['text']) ? NULL : $content['text'],

'template' => empty($content['template']) ? NULL : $content['template'],

'type' => empty($content['type']) ? 'post' : $content['type'],

'status' => empty($content['status']) ? 'publish' : $content['status'],

'password' => empty($content['password']) ? NULL : $content['password'],

'allowComment' => !empty($content['allowComment']) && 1 == $content['allowComment'] ? 1 : 0,

'allowPing' => !empty($content['allowPing']) && 1 == $content['allowPing'] ? 1 : 0,

'allowFeed' => !empty($content['allowFeed']) && 1 == $content['allowFeed'] ? 1 : 0,

'parent' => empty($content['parent']) ? 0 : intval($content['parent']),

'test_url' => empty($content['test_url']) ? NULL : $content['test_url'],

);

4.3 select函数里添加查询新字段:/**

* 获取查询对象

*

* @access public

* @return Typecho_Db_Query

*/

public function select()

{

return $this->db->select('table.contents.cid', 'table.contents.title', 'table.contents.slug', 'table.contents.created', 'table.contents.authorId',

'table.contents.modified', 'table.contents.type', 'table.contents.status', 'table.contents.text', 'table.contents.commentsNum', 'table.contents.order',

'table.contents.template', 'table.contents.password', 'table.contents.allowComment', 'table.contents.allowPing', 'table.contents.allowFeed',

'table.contents.parent','table.contents.test_url')->from('table.contents');

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值