十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
update tbltest set percent = 100*value/(select sum(value) from tbltest)||'%';
创新互联公司一直通过网站建设和网站营销帮助企业获得更多客户资源。 以"深度挖掘,量身打造,注重实效"的一站式服务,以成都做网站、网站建设、移动互联产品、成都全网营销推广服务为核心业务。10余年网站制作的经验,使用新网站建设技术,全新开发出的标准网站,不但价格便宜而且实用、灵活,特别适合中小公司网站制作。网站管理系统简单易用,维护方便,您可以完全操作网站资料,是中小公司快速网站建设的选择。
MySql不支持选取前百分之几的记录,但是可以通过存储过程来实现,请参见下列实验:
查看学生表的总行数:
mysql select count(*) as rows from students;
向变量赋值@percent 取前50%的行数:
mysql select count(*)*50/100 into @percent from students;
预设SQL语句:
mysql prepare stmt from "select * from students limit ?";
运行预设SQL语句:
mysql execute stmt using @percent;
请参见附图
这样就实现了选取前50%的记录(全部6条记录中的前3条也就是50%)
myisam直接count然后limit取。innodb count记得用二级索引作为条件。count(*)from table where uid0 . 这样。不然不准还慢。