• 域名认证
  • 认证:9|
  • 升级:19|
  • 技术:34|
  • 模板:45|

导航
欢迎来到模板网
  • 正文开始
  • 最新上架模板
如何批量从帝国cms的内容字段提取图片,作为标题图片?办法很多,可以用字段函数, 可以在内容模板里的加php代码处理,也可以用二开助手方便准确的完成。但是,总有那么一些大牛人,希望执行sql语句,一键搞定。
假定内容字段为newstext,存在副表中,假定是新闻表。那么副表就是[!db.pre!]ecms_news_data_1,主表是 [!db.pre!]ecms_news。
需要考虑以下几点:
1. 数据表的newstext内容,不是纯洁的,是用addslashes函数处理过的。
2. 假定 newstext的html代码正规,图片具体这样的格式 src="***.jpg" ,那么在数据库中是这样存储的 src=\"***.jpg\"
3.  反斜杠真是个讨厌的东西,可是我们离不了他,在mysql语句中,我们用一个函数 来生成字符串\",这个函数就是char(92,34)
看语句:
update [!db.pre!]ecms_news_data_1 a, [!db.pre!]ecms_news b set b.titlepic=concat(replace(SUBSTRING_INDEX(SUBSTRING_INDEX(a.newstext, 'src=', -1),'.jpg',1),char(92,34),''),'.jpg') where a.newstext like '%.jpg%' and b.titlepic='' and a.id=b.id;

他可以取出newstext字段中的,最后一张图片,如果标题图片为空的话,就用这图片了。

类似的,如果取第一张图片,应该使用代码

update [!db.pre!]ecms_news_data_1 a, [!db.pre!]ecms_news b set b.titlepic=concat(replace(SUBSTRING_INDEX(SUBSTRING_INDEX(a.newstext, '.jpg', 1),'src=',-1),char(92,34),''),'.jpg') where a.newstext like '%.jpg%' and b.titlepic='' and a.id=b.id;
收藏此文 ( ) 赞一个 打赏本站

如果本文对你有所帮助请打赏本站

  • 打赏方法如下:
  • 支付宝打赏
    支付宝扫描打赏
    微信打赏
    微信扫描打赏
站长资讯
更新时间: 2019-08-21

107 人已经看过了!

更新时间: 2019-08-21

94 人已经看过了!

更新时间: 2019-08-21

88 人已经看过了!

更新时间: 2019-08-21

73 人已经看过了!

更新时间: 2019-08-20

87 人已经看过了!

更新时间: 2019-08-20

66 人已经看过了!

更新时间: 2019-08-20

95 人已经看过了!