@fife

При добавлении в maven зависимости для JDBC, версия красная. Как решить?

Добрый вечер, решил заняться изучением Sql на практике вместе с кодом. Не выходит начать работу из за ошибки что не может найти драйвер.
Так же не могу понять причину, по которой в maven при добавлении зависимости, версия выделяется красным цветом.
Базу создал через PGadmin, так что она точно есть.

Exception in thread "main" java.sql.SQLException: No suitable driver found for jdbc:postgresql://localhost:5432/intellijdb
	at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:702)
	at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:228)
	at Main.main(Main.java:10)


<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>maven jdbc</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>42.2.1</version>
        </dependency>
    </dependencies>
    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
    </properties>
</project>


import java.sql.*;

public class Main {
    public static void main(String[] args) throws SQLException {
        final String user = "postgres";
        final String pass = "admin";
        final String url = "jdbc:postgresql://localhost:5432/intellijdb";

        final Connection connection = DriverManager.getConnection(url,user,pass);

        try(PreparedStatement statement = connection.prepareStatement("SELECT * from Phones WHERE id = (?)")){
            statement.setInt(1,1);
            final ResultSet resultSet = statement.executeQuery();
            if(resultSet.next()){
                String name = resultSet.getString("UserLogin");
                System.out.println(name);
            }
        }finally {
            connection.close();
        }
    }
}
  • Вопрос задан
  • 2016 просмотров
Решения вопроса 1
xez
@xez Куратор тега Java
TL Junior Roo
mvn clean install В консоли.
И кнопочку типа "обновить" в закладке Maven
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

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