- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的 View (show.php),其中有类(class)(每门类(class)有 2-4 节课)
<table width="100%" class="table table-striped table-bordered table-hover" id="dataTables-mot">
<?php
if (count($corsi) > 0) {
foreach ($corsi as $mm) {
$lezioni=$mm->getLessons($mm->cou_id);
echo "<tr class='odd gradeX'>";
foreach ($lezioni as $lez) {
$data=date('d-m-Y', (float)$lez->les_ts);
$ora=date('H:i', (float)$lez->les_ts);
echo "
<td><span style=\"display: none;\">". $lez->les_ts."</span>
<a href='?controller=courses&action=manageMoto&id=" . $mm->cou_id . "'>" . $data . "
<div>".$ora."</div>
</td>";
}
}
}
else {
echo "<tr class='odd gradeX'><td>Nessun corso presente.</td><td></td><td><td></td><td></tr>";
}
?>
</table>
这是 Controller (courses.controller):
<?php
class CoursesController {
public $tipo;
public function show() {
//I set the course type
if (isset($_GET['type'])) {
$this->tipo=$_GET['type'];
}
$lezioni=getNumberLessonsByCourseType($this->getTipo());
$corsi = Course::getCoursesbyType($this->getTipo());
require_once('views/courses/show.php');
}
}
?>
还有 course_model.php
<?php
include_once("connection.php");
include_once("model.php");
include_once("lessons_model.php");
Class Course extends Model{
public $cou_id;
public $cou_type;
public $cou_status;
public $cou_fbid;
public function __construct($cou_id=null, $cou_type=null, $cou_status=null, $cou_fbid=null)
{
$this->cou_id = $cou_id;
$this->cou_type = $cou_type;
$this->cou_status = $cou_status;
$this->cou_fbid = $cou_fbid;
}
public static function getCoursesbyType($type) {
$connection= new Database();
$selectCou = $connection->prepare('SELECT * FROM courses WHERE cou_type = :type order by cou_id desc');
$selectCou->bindParam(':type', $type, PDO::PARAM_INT);
$selectCou->execute();
$list = [];
foreach($selectCou->fetchAll() as $corso) {
$list[] = new Course($corso['cou_id'], $corso['cou_type'], $corso['cou_status'],$corso['cou_fbid']);
}
return $list;
$connection=null;
}
public static function getLessons($id) {
$connection= new Database();
$id = intval($id);
$selectLess = $connection->prepare('SELECT * FROM lessons WHERE les_course = :id');
$selectLess->bindParam(':id', $id, PDO::PARAM_INT);
$selectLess->execute();
$list = [];
foreach($selectLess->fetchAll() as $lezione) {
$list[] = new Lesson($lezione['les_id'], $lezione['les_course'], $lezione['les_ts'],$lezione['les_number'],$lezione['les_instructor']);
}
return $list;
$connection=null;
}
}
我还有 Lesson_model.php (对于每门类(class),我都有一系列类(class))
Class Lesson extends Model{
public $les_id;
public $les_course;
public $les_ts;
public $les_number;
public $les_instructor;
public function __construct($les_id=null, $les_course=null, $les_ts=null, $les_number=null, $les_instructor=null)
{
$this->les_id = $les_id;
$this->les_course = $les_course;
$this->les_ts = $les_ts;
$this->les_number = $les_number;
$this->les_instructor = $les_instructor;
}
}
getNumberLessonsByCourseType 是一个简单的函数:
function getNumberLessonsByCourseType($course) {
switch($course){
case 'mot': $number=3; break;
case 'mos': $number=3; break;
case 'mop': $number=2; break;
case 'sam': $number=2; break;
case 'sen': $number=4; break;
}
return $number;
}
问题是,当我调用 Controller (方法显示)时,我需要几乎 10 秒的时间才能完成所有类(class)以及每个类(class)的类(class)。太慢了。Workbench中查询不慢,而且类(class)有700门,所以不多。
最佳答案
问题是:您有 700 门类(class) - 每门类(class)都运行 $lezioni=$mm->getLessons($mm->cou_id);
,其中执行 SQL 查询。因此,如果获取类(class)的查询在 15 毫秒内执行(可以认为很快),那么其中 700 个查询将花费大约 10 秒。
您可以做的是在一个查询中获取所有类(class)的所有类(class),并将它们分配给 PHP 类(class)。
Class Course extends Model{
// ...
public $lessons = [];
// ...
public static function getCoursesWithLessonsByType($type) {
$connection = new Database();
$selectCou = $connection->prepare('
SELECT *
FROM courses
WHERE cou_type = :type
order by cou_id desc
');
$selectCou->bindParam(':type', $type, PDO::PARAM_INT);
$selectCou->execute();
$list = [];
foreach($selectCou->fetchAll() as $corso) {
$list[$corso['cou_id']] = new Course(
$corso['cou_id'],
$corso['cou_type'],
$corso['cou_status'],
$corso['cou_fbid']
);
}
$selectLess = $connection->prepare('
SELECT l.*
FROM lessons l
JOIN courses c ON c.cou_id = l.les_course
WHERE c.cou_type = :type'
);
$selectLess->bindParam(':type', $type, PDO::PARAM_INT);;
$selectLess->execute();
foreach($selectLess->fetchAll() as $lezione) {
$list[$lezione['les_course']]->lessons[] = new Lesson(
$lezione['les_id'],
$lezione['les_course'],
$lezione['les_ts'],
$lezione['les_number'],
$lezione['les_instructor']
);
}
return $list;
}
// ...
}
在你的 Controller 中:
$corsi = Course::getCoursesWithLessonsByType($this->getTipo());
您认为:
$lezioni = $mm->lessons;
您不应该在每次要运行查询时都打开和关闭连接。至少使用像这样的单例:
$connection = Database::getInstance();
为了获得最佳性能,您应该具有以下索引:
courses(cou_type, cou_id)
或只是 courses(cou_type)
,如果 cou_id
是主键,则相同lessons(les_course[, ...])
- 可以是复合索引,但必须以 les_course
开头关于php - 使用类时查询速度慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44332009/
我的应用程序中有以下查询: SELECT a.*, f.* FROM flights_database f JOIN airports a ON f.airport = a.airportNameCl
我们在使用 MySQL(以及 MariaDB)时遇到了一个奇怪的问题。一个简单的数据库,有 2 个表(InnoDB 引擎),都包含(以及其他一些)3 或 4 个带有 XML 数据的文本列。大小为 1-
我在 MySQL 上的执行路径上遇到问题,导致查询缓慢且不一致。这是一个全新的现象。我们还有其他具有完全相同(好吧,尽可能接近)设置的表,这很好,但出于某种原因,现在创建新表会遇到这个缓慢/不一致的问
我使用 Eclipse Marketplace 的下载速度始终非常慢(现在从 http://download.eclipse.org 开始,下载速度为 3 MB/s,下载速度为 25 kB/s),这使
我正在开发一个 Qt Creator 项目,其中包含大量头文件(点云库、Boost 等)。例如。 Boost 有大约 9000 个头文件。现在看来,包含的数量确实减慢了 IDE。代码完成很慢,大约。
我在一个项目中使用 document.elementFromPoint,它看起来很慢。 100,000 次迭代需要 7051 毫秒。 document.getElementsByTagName("*"
我有一个 tableView ,每行有四个图表,大约 20 行。当我尝试滚动表格时,我将删除现有图表并为每一行构建新图表。 此操作使 TableView 的滚动非常慢。任何使滚动速度更快以及加载新图表
我有一个如下所示的数据框: date,time,metric_x 2016-02-27,00:00:28.0000000,31 2016-02-27,00:01:19.0000000,40 2016-
TLDR:我的微调器瞬间显示了错误的颜色。 我的微调器有问题。每当我运行应用程序时,如果 Activity 没有缓存在内存中,它有时会滞后。在我可以将其设置为正确的颜色之前,文本是默认颜色(如黑色)。
我在使用 SELECT COUNT(*) 对大型表进行 SQLite 时遇到性能问题。 由于我还没有收到可用的答案并且我做了一些进一步的测试,所以我编辑了我的问题以纳入我的新发现。 我有 2 个表:
当音频因加载数据不足(速度慢)而暂停时,我可以使用什么事件? 就像: $audio.on('suspendToLoading',function(){ alert('loading...');
这是我的 MATLAB 程序的分析模拟运行结果。我需要运行此模拟数十万次(约 100,000 次)。 因此我需要一种更快的方法来读取 Excel 文件。 规范:Excel 文件由 10000x2 个单
每当与数据透视表交互时,Excel 都非常慢,这让我感到非常困难。添加/删除字段、更改过滤器或切片器,所有这些都需要 Excel 卡住几分钟才能响应。 看来生成的 MDX 效率极低。我可以理解他们必须
我正在使用 Entity Framework 来检索大型数据集。 数据集有parent/child关系,我需要和parent同时带回child信息。 我发现 EF 最初发送一个查询以获取父对象列表,然
我有一个使用 gridview 的应用程序,它非常慢。 添加 Trace=true 后对于页面,我追踪了时间花费的地方:在 GridView 上调用 BindData() 时。 GridView连接到
我编写了一个小代码来使用 QtCreator 测试 QGraphicsView 的功能。 代码非常简单,只是创建了一个继承自 QGraphicsView 的类,上面有一个 QGraphicsScene
后期以补充作品的形式自动加入成员(member)。数据库速度较慢。有没有办法加快这个速度?用户无所谓..除了自动补码之外如何停止写?(自动补码;城市输入。成员(member)表格位于。) 注册.php
我有一个文件 (insert.sql),其中有 250k 行,没有键,没有索引: INSERT `project_383`.`entity_metrics_build_1` VALUES ('d402
我最近开发了一个应用程序(java 8、spring-boot、hibernate、maven),它通过 REST API 公开数据库。我遇到的问题是数据库调用很慢(3000 毫秒以上),只是为了获取
我正在尝试在 Canvas 上使用旋转,我现在有了它,因此每个对象都有自己的旋转。如果没有它们旋转,我可以在一台非常低端的计算机上在屏幕上显示大约 400 个对象,在一台正常库存的计算机上显示近 20
我是一名优秀的程序员,十分优秀!