如何批量从帝国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;
|