Итак, вы хотите сосчитать первую дату, когда клиент появляется в таблице. Другими словами, строка, для которой не существует другой строки с более ранней датой и тем же клиентом. Вы можете сделать это с помощью исключения .
Тогда вы можете считать их в год, как вы делаете сейчас.
SELECT YEAR(t.date) AS yr, COUNT(t.client_id) AS client_count
FROM (
SELECT t1.client_id, t1.date
FROM mytable AS t1
LEFT JOIN mytable AS t2 ON (t1.client_id=t2.client_id AND t1.date > t2.date)
WHERE t2.client_id IS NULL) AS t
GROUP BY yr
Вы должны хранить даты, используя тип данных DATE, который использует формат ГГГГ-ММ-ДД. Вы не сможете выполнять >
сравнения, если ваши даты хранятся в виде строк в формате DD-MM-YYYY.
Я не думаю, что это проблема в плагине Maven или Surefire. Иначе верный ведет себя по-другому. Похоже, теперь, когда Surefire разветвляет JVM , не будет принимать все системные свойства у родительской JVM.
Вот почему вы должны передавать любые системные свойства, которые вы хотите для тестов, используя argLine. Итак, оба они должны работать
mvn2.1 -Dsystem.test.property=test test -DforkMode=never
или
mvn2.1 test -DargLine="-Dsystem.test.property=test"
Я испытал это с плагином Surefire . Подключаемый модуль Surefire запускается под другим экземпляром JVM, который запускается Maven. Параметры командной строки можно настроить в конфигурации surefile-plugin в вашем pom.xml. Вот образец нашей конфигурации.
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.4.3</version>
<!--
By default, the Surefire Plugin will automatically include all test classes with the following wildcard patterns:
"**/Test*.java" - includes all of its subdirectory and all java filenames that start with "Test". "**/*Test.java" -
includes all of its subdirectory and all java filenames that end with "Test". "**/*TestCase.java" - includes all of
its subdirectory and all java filenames that end with "TestCase".
-->
<configuration>
<includes>
<include>**/*Test.java</include>
</includes>
<systemProperties>
<property>
<name>app.env</name>
<value>dev</value>
</property>
<property>
<name>oracle.net.tns_admin</name>
<value>${oracle.net.tns_admin}</value>
</property>
</systemProperties>
</configuration>
</plugin>
Будьте осторожны, чтобы не перепутать файл конфигурации с аргументами командной строки. Файл конфигурации (pom.xml) переопределяет все аргументы cmd. Поэтому не настраивайте плагин surefire в pom.xml, если вы хотите передать его через командную строку, как объяснил raisercostin.