para encontrar los números primos

Estoy intentando ejecutar este código para imprimir la suma de todos los números primos de menos de 2 millones. Este bucle nunca termina. ¿Alguien puede decirme qué está mal con el código? Aunque parece funcionar con números más pequeños.

public static void main(String[] args) {

        long result = 1;

        for(int i=0; i<2000000; i++) {
            if(isPrime(i)) {
                result+= i;
            }
        }
        System.out.println(result);

    }
private static boolean isPrime(long n) {
    boolean result = false;

    for(long i=2; i<(long)Math.sqrt(n); i++) {
        if(n%i == 0) {
            result = false;
            break;
        }
        else result = true;
    }
    return result;
}

Respuestas a la pregunta(5)

Su respuesta a la pregunta