2015-01-13 42 views
-1
select * from events where detector='PhotoWatcher' 
    AND TIMESTAMPDIFF(second,(select event_occured from events where description 
    LIKE '%Lat:18%' OR '%Lng:73%' LIMIT 1), 
    (select event_occured from events where detector='PhotoWatcher' LIMIT 1))>0; 

它們是否作爲嵌套的「for」循環執行?或與RESULT2的第一排RESULT1的第一排任何人都可以幫助我理解TIMESTAMPDIFF中查詢的執行情況

+0

把'EXPLAIN'放在你的查詢前,MySQL會告訴你。檢查['EXPLAIN'輸出格式](http://dev.mysql.com/doc/refman/5.7/en/explain-output.html)以瞭解如何改進其運行時間。 – axiac

回答

0

假設我們有以下的嵌套DO循環:

DO 
    statements-1 
    DO 
     statement-2 
    END DO 
    statement-3 
END DO 

外DO的每一次迭代開頭的語句-1。當控制達到內部DO時,執行語句-2,直到內部DO的某些條件將控制移出。然後,執行語句-3並完成一次迭代。內部DO中的任何EXIT都會將控制權從內部DO中移出到語句-3中的第一個語句。

以下是一些簡單的例子:

在下面的嵌套循環,外層一個具有i從1運行至9與步驟尺寸1.對於每次迭代,說的第i個,內循環迭代9次,其中j的值爲1,2,3,4,5,6,7,8,9。因此,在i固定的情況下,WRITE被執行9次,並且輸出由i * 1,i * 2,i * 3,...,i * 9。

INTEGER :: i, j 

DO i = 1, 9 
    DO j = 1, 9 
    WRITE(*,*) i*j 
    END DO 
END DO 

一旦做到這一點,我的價值是前進到下一個,而內循環將迭代9次再次顯示新的I和1,2,3,4的產品... ,9.

淨效應是一個乘法表。對於i = 1,顯示1 * 1,1 * 2,1 * 3,...,1 * 9的值;對於i = 2,顯示值爲2 * 1,2 * 2,2 * 3,...,2 * 9; ...;對於i = 9,顯示值爲9 * 1,9 * 2,9 * 3,...,9 * 9。
下面顯示了一個嵌套的DO循環。外面的一個讓你從2運行到5.對於每個你,內在的DO讓v從1運行到u-1。因此,當u是2時,v的值從1到1.當u是3時,v的值是1和2.當u是4時,v的值是1,2和3.最後,當u是5,v的值是1,2,3和4

INTEGER :: u, v 
INTEGER :: a, b, c 

DO u = 2, 5 
    DO v = 1, u-1 
     a = 2*u*v 
     b = u*u - v*v 
     c = u*u + v*v 
     WRITE(*,*) a, b, c 
    END DO 
END DO 

上面的討論可以概括於下表中:

u Values for v 
2 1 


3 1 2 

4 1 2 3 
5 1 2 3 4 

對於每一對u的和v,內部循環計算a,b和c。因此,將產生以下結果(請驗證):

u v a b c 
2 1 4 3 5 
3 1 6 8 10 
2 12 5 13 
4 1 8 15 17 
2 16 12 20 
3 24 7 25 
5 1 10 24 26 
2 20 21 29 
3 30 16 34 
4 40 9 41 

顯而易見的是,內部的DO循環計算所有整數的和在範圍1和i(即,總和等於1 + 2 + 3 + ... + I)。由於我運行從1到10,下面的循環計算十個和:1,1 + 2,1 + 2 + 3,1 + 2 + 3 + 4,...,1 + 2 + 3 + ... + 9和1 + 2 + 3 + ... + 9 + 10。

INTEGER :: i, j, Sum 

DO i = 1, 10 
    Sum = 0 
    DO j = 1, i 
     Sum = Sum + j 
    END DO 
    WRITE(*,*) Sum 
END DO 

下面的程序使用牛頓的方法來計算正數的平方根。實際上,它計算了數字0.1,0.1,...,0.9和1.0的平方根。

REAL :: Start = 0.1, End = 1.0, Step = 0.1 
REAL :: X, NewX, Value 

Value = Start 
DO 
    IF (Value > End) EXIT 
    X = Value 
    DO 
     NewX = 0.5*(X + Value/X) 
     IF (ABS(X - NewX) < 0.00001) EXIT 
     X = NewX 
    EBD DO 
    WRITE(*,*) 'The square root of ', Value, ' is ', NewX 
    Value = Value + Step 
END DO 

牛頓法是直接從編程實例截取,其中,X是當前猜想,下一頁末是新猜測,並且值是用於平方根計算的數量。 EXIT語句將內部DO的執行引入WRITE語句。

如果內環路解除,我們有外部循環如下:

REAL :: Start = 0.1, End = 1.0, Step = 0.1 
REAL :: X, NewX, Value 

Value = Start 
DO 
    IF (Value > End) EXIT 
! 
! the inner loop computes the result in NewX 
! 
    WRITE(*,*) 'The square root of ', Value, ' is ', NewX 
    Value = Value + Step`enter code here` 
END DO 

清楚的是,值的值與0.1開始,並具有步長0.1直至1.0。因此,Value的值是0.1,0.2,0.3,...,0.9和1.0。對於Value的每個值,內部循環計算Value的平方根。外循環中的EXIT語句將控制移出外循環。

相關問題