2015-12-20 179 views
2

儘管Maven解決了依賴關係,並且它在我的項目設置中顯示爲模塊(因此應該在類路徑中),但IntelliJ不允許我導入com.microsoftIntelliJ無法找到從Maven的sqljdbc4.jar即使它解決?

enter image description here

外部依賴解析: 模塊: enter image description here

POM文件中有這樣的:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 
    <groupId>com.arcologydesigns.rest</groupId> 
    <artifactId>ads-webapp</artifactId> 
    <packaging>war</packaging> 
    <version>0.0.1-SNAPSHOT</version> 
    <name>springexample Maven Webapp</name> 
    <url>http://maven.apache.org</url> 

    <properties> 
     <endorsed.dir>${project.build.directory}/endorsed</endorsed.dir> 
     <spring.version>4.0.5.RELEASE</spring.version> 
     <jdk.version>1.8</jdk.version> 
     <jackson.version>2.2.3</jackson.version> 
     <!--<sqlserver.version>4.2.6420.100</sqlserver.version>--> 
     <sqlserver.version>4</sqlserver.version> 
     <build.scm.revision>SCM_IDENTIFIER</build.scm.revision> 
     <build.number>BUILD_NUMBER</build.number> 
     <build.id>BUILD_ID</build.id> 
     <build.job.name>BUILD_JOB_NAME</build.job.name> 
    </properties> 

    <dependencies> 
     <dependency> 
      <groupId>junit</groupId> 
      <artifactId>junit</artifactId> 
      <version>3.8.1</version> 
      <scope>test</scope> 
     </dependency> 

     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-core</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-webmvc</artifactId> 
      <version>${spring.version}</version> 
     </dependency> 

     <dependency> 
      <groupId>com.microsoft.sqlserver</groupId> 
      <artifactId>sqljdbc4</artifactId> 
      <version>${sqlserver.version}</version> 
     </dependency> 

     <dependency> 
      <groupId>org.json</groupId> 
      <artifactId>json</artifactId> 
      <version>20120521</version> 
     </dependency> 

    </dependencies> 
    <build> 
     <finalName>ads-webapp</finalName> 
    </build> 
</project> 

我用下面安裝了sqljdbc驅動程序(這是我從MSDN下載) Maven:http://techmajik.com/2014/04/24/how-to-setup-maven-dependency-for-microsoft-sql-server/

回答

1

嘗試添加它directtly到Maven倉庫這樣的:

mvn install:install-file -Dfile=sqljdbc4.jar -Dpackaging=jar -DgroupId=com.microsoft.sqlserver -DartifactId=sqljdbc4 -Dversion=4.0 

,然後添加到您的pom.xml

<dependency> 
<groupId>com.microsoft.sqlserver</groupId> 
<artifactId>sqljdbc4</artifactId> 
<version>4.0</version> 

更多detailes你可以閱讀這個話題:

http://claude.betancourt.us/add-microsoft-sql-jdbc-driver-to-maven/

您需要這樣做,因爲SQL Server驅動程序不是包含在Maven倉庫中 - 你需要自己安裝它。

+1

該鏈接不再有效。搜索「sqljdbc4」並顯示Microsoft下載頁面。解壓縮下載,然後運行maven命令。 – scottheckel

0

您可以直接使用下面的依賴:

<dependency> 
<groupId>com.microsoft.sqlserver</groupId> 
<artifactId>mssql-jdbc</artifactId> 
<version>6.1.0.jre8</version> </dependency> 
0

老sqljdbc驅動器(V 4.0)jar文件可在Maven的回購協議: https://mvnrepository.com/artifact/com.microsoft.sqlserver/sqljdbc4/4.0

下載和使用命令進行安裝通過照顧user4198625提到

  • 確保行家(MVN)在您的PATH
  • JAVA_HOME已在您的env變量(適用於Windows)中正確定義。如果您正在運行mvn批處理文件,這尤其重要。
  • 要使命令按原樣工作,需要從jar文件所在的目錄執行它。
相關問題