Знаток 2.1.0 не переходящий системные свойства к виртуальной машине Java

Итак, вы хотите сосчитать первую дату, когда клиент появляется в таблице. Другими словами, строка, для которой не существует другой строки с более ранней датой и тем же клиентом. Вы можете сделать это с помощью исключения .

Тогда вы можете считать их в год, как вы делаете сейчас.

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.

38
задан acdcjunior 3 June 2013 в 05:58
поделиться

3 ответа

Я не думаю, что это проблема в плагине Maven или Surefire. Иначе верный ведет себя по-другому. Похоже, теперь, когда Surefire разветвляет JVM , не будет принимать все системные свойства у родительской JVM.

Вот почему вы должны передавать любые системные свойства, которые вы хотите для тестов, используя argLine. Итак, оба они должны работать

mvn2.1 -Dsystem.test.property=test test -DforkMode=never 

или

mvn2.1 test -DargLine="-Dsystem.test.property=test"
53
ответ дан 27 November 2019 в 03:37
поделиться

Я испытал это с плагином 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>
12
ответ дан 27 November 2019 в 03:37
поделиться

Будьте осторожны, чтобы не перепутать файл конфигурации с аргументами командной строки. Файл конфигурации (pom.xml) переопределяет все аргументы cmd. Поэтому не настраивайте плагин surefire в pom.xml, если вы хотите передать его через командную строку, как объяснил raisercostin.

2
ответ дан 27 November 2019 в 03:37
поделиться
Другие вопросы по тегам:

Похожие вопросы: