百独托管7500 紫田网络超高转化播放器收cps[推荐]速盾CDN 免实名免备防屏蔽阿里云 爆款特卖9.9元封顶提升alexa、IP流量7Q5团队
【腾讯云】中小企福利专场【腾讯云】多款产品1折起高防 随时退换 好耶数据小飞国外网赚带你月入万元炎黄网络4H4G10M 99每月
香港带宽CN2/美国站群优惠中客数据中心 服务器租用联盟系统移动广告平台 中易企业专场腾讯云服务器2.5折九九数据 工信部正规资质
腾讯云新用户大礼包代金券高价收cpa注册量高价展示【腾讯云】2核2G/9.93起租服务器找45互联 随时退换阿里云 短信服务 验证秒达

[闲聊畅谈] 30元话费有偿解决php语句。 [复制链接]
查看:772 | 回复:8

33

主题

424

帖子

1113

积分

落伍者(两全齐美)

Rank: 2

贡献
459
鲜花
1
注册时间
2008-12-23

落伍微信绑定落伍手机绑定

发表于 2019-4-17 17:34:51 | |阅读模式 来自 中国浙江杭州
dede系统中,php文件里我是这样写的:
$row_head = $dsql->GetOne('SELECT `description` FROM `dede_archives` WHERE `typeid`=10  ORDER BY rand() LIMIT 0,1');
$row_head =$row_head['description'];
$body = $row_head.$body.'<p><img src="'.$litpic.'" ></p>';
随机查询一条数据库中的内容摘要,然后把这条摘要放到文章的最前面。上面的语句不行,如果修改?
30元话费送给第一个解决问题的mjj

1066

主题

1万

帖子

7145

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
1206
鲜花
27
注册时间
2006-10-26

落伍手机绑定

发表于 2019-4-17 18:25:18 | 来自 中国广西钦州
SELECT * FROM article_list WHERE ClassID=18 ORDER BY rand() LIMIT 0,1
经测试这样的语句是没问题的

1066

主题

1万

帖子

7145

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
1206
鲜花
27
注册时间
2006-10-26

落伍手机绑定

发表于 2019-4-17 18:27:53 | 来自 中国广西钦州
建议直接在phpmyadmin里面运行你自己的语句看看是不是你想要的结果
然后再放到php程序里面

324

主题

1826

帖子

1万

积分

落伍者(四季发财)

广州BGP双线5M独享特价!

Rank: 4

贡献
85
鲜花
73
注册时间
2010-2-26

落伍手机绑定

发表于 2019-4-17 19:12:29 | 来自 中国湖南
  1. $row_head = $dsql->GetOne('SELECT `description` FROM `dede_archives` WHERE `typeid`=10  ORDER BY rand() LIMIT 0,1');
  2. $body = $row_head.$body.'<p><img src="'.$litpic.'" ></p>';
复制代码


改成这样就可以了

225

主题

5008

帖子

7302

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
5184
鲜花
16
注册时间
2007-12-28

落伍手机绑定

发表于 2019-4-17 19:40:51 来自落伍手机版 | 来自 中国广东
那若是随机查询当前栏目任意一条信息的摘要呢?$row_head = $dsql->GetOne('SELECT `description` FROM `dede_archives` WHERE `typeid`=10  ORDER BY rand() LIMIT 0,1'); $body = $row_head.$body.'<p><img src="'.$litpic.'" ></p>';不行

85

主题

4864

帖子

9655

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
5683
鲜花
28
注册时间
2005-6-1

落伍手机绑定

发表于 2019-4-17 20:11:01 | 来自 中国河北廊坊
不要用你当前的sql方式  order by + rand() 是全表扫描
速度极慢

建议用下面方式:

  1. $row_head = $dsql->GetOne('SELECT * FROM `dede_archives`  AS u1  JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `dede_archives`)-(SELECT MIN(id) FROM `dede_archives`))+(SELECT MIN(id) FROM `dede_archives`)) AS id) AS u2 WHERE u1.id >= u2.id and u1.`typeid`='10' ORDER BY u1.id limit 1');
复制代码


其他部分不变即可。可以试试。

723

主题

2万

帖子

5613

积分

落伍者(三羊开泰)

Rank: 3Rank: 3

贡献
361
鲜花
7
注册时间
2007-9-23

落伍手机绑定

发表于 2019-4-17 20:38:21 | 来自 中国广东深圳
楼上是专家

1

主题

228

帖子

72

积分

落伍者(一心一意)

Rank: 1

贡献
309
鲜花
0
注册时间
2005-11-26
发表于 2019-4-17 22:15:29 | 来自 中国河北邢台
观摩学习

33

主题

424

帖子

1113

积分

落伍者(两全齐美)

Rank: 2

贡献
459
鲜花
1
注册时间
2008-12-23

落伍微信绑定落伍手机绑定

 楼主| 发表于 2019-4-19 15:48:17 | 来自 中国浙江杭州
本帖最后由 cr3318 于 2019-4-19 15:51 编辑

谢谢各位大佬的意见。

原来我的代码是没有问题的,因为在dede里新建了一个文章模型,新的模板里没有调用新的php文件,导致我怎么改都不行。现在已经解决。

ps:4楼这样的代码是不行的。
论坛客服/商务合作/投诉举报:2171544 (QQ)
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号

  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2024-9-28 14:16 , Processed in 0.072061 second(s), 34 queries , Gzip On.

返回顶部