begin process at 2008 07 24 19:08:56
1 215 858 membres
413 nouveaux aujourd'hui
14 179 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

CONNEXION À UNE BASE DE DONNÉES SQL SERVER 2005


Information sur la source

Catégorie :JavaServerPage (JSP) Classé sous : sqlserver, connexion, connection, sql, sqlconnection Niveau : Débutant Date de création : 25/09/2006 Date de mise à jour : 26/09/2006 02:16:10 Vu : 21 623

Note :
9 / 10 - par 3 personnes
9,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (7)
Ajouter un commentaire et/ou une note

Description

Dans cet article, vous trouverez un moyen parmi d'autres afin de se connecter à une base de données SQL Server 2005 et d'effectuer une requête

Source

  • /*
  • La table plus simple il n'y a pas :
  • USE [jspTest]
  • GO
  • /****** Objet : Table [dbo].[test1] Date de génération du script : 09/25/2006 23:23:06 ******/
  • SET ANSI_NULLS ON
  • GO
  • SET QUOTED_IDENTIFIER ON
  • GO
  • CREATE TABLE [dbo].[test1](
  • [id] [int] IDENTITY(1,1) NOT NULL,
  • [prenom] [nchar](50) COLLATE French_CI_AS NOT NULL,
  • [nom] [nchar](50) COLLATE French_CI_AS NOT NULL,
  • CONSTRAINT [PK_test1] PRIMARY KEY CLUSTERED
  • (
  • [id] ASC
  • )WITH (PAD_INDEX = OFF, IGNORE_DUP_KEY = OFF) ON [PRIMARY]
  • ) ON [PRIMARY]
  • */
  • // 1 - la classe permettant d'accéder aux données :
  • /*
  • * SqlConnection.java
  • *
  • * Created on 23 septembre 2006, 12:26
  • *
  • * To change this template, choose Tools | Template Manager
  • * and open the template in the editor.
  • */
  • package sqlserver.mydb.common;
  • /**
  • *
  • * @author david
  • */
  • import java.io.*;
  • import java.sql.*;
  • public class SqlConnection {
  • /**
  • * Creates a new instance of SqlConnection
  • */
  • public SqlConnection() {
  • }
  • private String driver;
  • private String url;
  • private Connection cnx;
  • private Statement st;
  • public boolean ConnectToSQL()
  • {
  • try
  • {
  • Class.forName(getDriver());
  • cnx=DriverManager.getConnection(getUrl());
  • st=cnx.createStatement();
  • return true;
  • }
  • catch(SQLException ex)
  • {
  • System.out.println(ex.getMessage().toString());
  • return false;
  • }
  • catch(ClassNotFoundException ex)
  • {
  • System.out.println(ex.getMessage().toString());
  • return false;
  • }
  • }
  • public boolean CloseSql()
  • {
  • try
  • {
  • this.cnx.close();
  • return true;
  • }
  • catch(SQLException ex)
  • {
  • System.out.println(ex.getMessage().toString());
  • return false;
  • }
  • }
  • public ResultSet Requete(String req)
  • {
  • ResultSet rs=null;
  • try{
  • rs=st.executeQuery(req);
  • return rs;
  • }
  • catch(SQLException ex)
  • {
  • rs=null;
  • return rs;
  • }
  • }
  • public String getDriver() {
  • return driver;
  • }
  • public void setDriver(String driver) {
  • this.driver = driver;
  • }
  • public String getUrl() {
  • return url;
  • }
  • public void setUrl(String url)
  • {
  • this.url=url;
  • }
  • }
  • // 2 - La page jsp
  • <%@page contentType="text/html"%>
  • <%@page pageEncoding="UTF-8"%>
  • <%@page import="java.sql.*" %>
  • <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
  • "http://www.w3.org/TR/html4/loose.dtd">
  • <html>
  • <head>
  • <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  • <title>JSP Page</title>
  • </head>
  • <body>
  • <h1>JSP Page</h1>
  • <%
  • boolean isOK=false;
  • sqlserver.mydb.common.SqlConnection myConn=new sqlserver.mydb.common.SqlConnection();
  • myConn.setDriver("com.microsoft.sqlserver.jdbc.SQLServerDriver");
  • myConn.setUrl("jdbc:sqlserver://localhost:1433;databaseName=jspTest;user=*****;password=******");
  • isOK=myConn.ConnectToSQL();
  • if(!isOK)
  • {
  • out.println("Erreur");
  • }
  • else
  • {
  • out.println("OK");
  • ResultSet rs1=myConn.Requete("select * from test1");
  • int i=0;
  • while(rs1.next()){
  • i++;
  • out.println("<li>" + i + " " + rs1.getString("Prenom") + "-" + rs1.getString("nom"));
  • }
  • myConn.CloseSql();
  • }
  • %>
  • </body>
  • </html>
/*
La table plus simple il n'y a pas :
USE [jspTest]
GO
/****** Objet :  Table [dbo].[test1]    Date de génération du script : 09/25/2006 23:23:06 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[test1](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[prenom] [nchar](50) COLLATE French_CI_AS NOT NULL,
	[nom] [nchar](50) COLLATE French_CI_AS NOT NULL,
 CONSTRAINT [PK_test1] PRIMARY KEY CLUSTERED 
(
	[id] ASC
)WITH (PAD_INDEX  = OFF, IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]

*/


// 1 - la classe permettant d'accéder aux données :
/*
 * SqlConnection.java
 *
 * Created on 23 septembre 2006, 12:26
 *
 * To change this template, choose Tools | Template Manager
 * and open the template in the editor.
 */

package sqlserver.mydb.common;

/**
 *
 * @author david
 */

import java.io.*;
import java.sql.*;

public class SqlConnection {
    
    /**
     * Creates a new instance of SqlConnection
     */
    public SqlConnection() {
    }
    
    private String driver;
    private String url;
    
    private Connection cnx;
    private Statement st;
    
    public boolean ConnectToSQL()
    {
        try
        {
            Class.forName(getDriver());
            cnx=DriverManager.getConnection(getUrl());
            st=cnx.createStatement();
            return true;
        }
        catch(SQLException ex)
        {
            System.out.println(ex.getMessage().toString());
            return false;
        }
        catch(ClassNotFoundException ex)
        {
            System.out.println(ex.getMessage().toString());
            return false;
        }
    }
    
    public boolean CloseSql()
    {
        try
        {
            this.cnx.close();
            return true;
        }
        catch(SQLException ex)
        {
            System.out.println(ex.getMessage().toString());
            return false;
        }
    }

    public ResultSet Requete(String req)
    {
        ResultSet rs=null;
            
        try{
            rs=st.executeQuery(req);
            return rs;
        }
        catch(SQLException ex)
        {
            rs=null;
            return rs;
        }
    }
    
    public String getDriver() {
        return driver;
    }

    public void setDriver(String driver) {
        this.driver = driver;
    }

    public String getUrl() {
        return url;
    }
    
    public void setUrl(String url)
    {
        this.url=url;
    }
}

// 2 - La page jsp
<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@page import="java.sql.*" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
   "http://www.w3.org/TR/html4/loose.dtd">

<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
    <h1>JSP Page</h1>
    
    <%
        boolean isOK=false;
        sqlserver.mydb.common.SqlConnection myConn=new sqlserver.mydb.common.SqlConnection();
        
        myConn.setDriver("com.microsoft.sqlserver.jdbc.SQLServerDriver");
        myConn.setUrl("jdbc:sqlserver://localhost:1433;databaseName=jspTest;user=*****;password=******");
       
        isOK=myConn.ConnectToSQL();
        if(!isOK)
        {
            out.println("Erreur");
        }
        else
        {
            out.println("OK");
            ResultSet rs1=myConn.Requete("select * from test1");
            int i=0;
            
            while(rs1.next()){
                i++;
                out.println("<li>" + i + " " + rs1.getString("Prenom") + "-" + rs1.getString("nom"));
            }
            
            myConn.CloseSql();
        }
    %>

    </body>
</html>

Conclusion

Pour cet article j'ai utilisé, Netbeans 5.5 beta 2, SQL Server 2005 std et Sun Application server PE 9
25 septembre 2006 23:32:43 :
un import de trop oups ;)
26 septembre 2006 00:00:39 :
faute d'ortographe
26 septembre 2006 02:16:10 :
maj
  • signaler à un administrateur
    Commentaire de Ombitious_Developper le 26/09/2006 09:23:55

    Salut :

    Juste une remarque concernant l'initialisation du pilote de la base de données,
    il vaut mieux le mettre dans un bloc statique ou au début de la fonction main pourqu'il soit appeler au plus une seule fois indépendemment des instances créer à partir de votre classe.

    // 1- Solution 1:
    public class SqlConnection {
       static {
           try {
                  Class.forName ("driver");
           }
           catch (ClassNotFoundException e) {
                  e.printStackTrace ();
                  Syste.exit (1);
           }
       }
       // ...
    }
    // 2- Solution 2:
    public static void main (String [] args) {
           try {
                  Class.forName ("driver");
           }
           catch (ClassNotFoundException e) {
                  e.printStackTrace ();
                  Syste.exit (1);
           }
           //...
    }
    }

  • signaler à un administrateur
    Commentaire de davidyannick le 26/09/2006 12:17:55

    effectivement c'est une erreur de conception de ma part, merci de votre remarque

  • signaler à un administrateur
    Commentaire de walidsaad le 03/10/2006 10:49:30

    bravo

  • signaler à un administrateur
    Commentaire de acidburn09 le 24/05/2007 02:23:34

    Salut,

    Je suis un petit nouveau dans le langage Java et je commence à tenter de me connecter à des bases de données sql server.
    J'ai vu votre code et il semble très bien, cependant, lorsque j'utilise le pilote "com.microsoft.sqlserver.jdbc.SQLServerDriver" dans mon programme, ça me dit que le pilote n'a pu être trouvé. Je suis donc incapable de me connecter à la base de donnée. Est-ce que j'aurais oublié quelque chose ?

    J'aurais aussi une interrogation concernant la connection à la base de donnée. Je me connecte à une base de donnée sur un réseau. Est-ce qu'il est permis de mettre plusieurs niveau de serveurs dans la string de connection ? Exemple: "jdbc:sqlserver://sql5/bdDept;databaseName=nomSchema".

  • signaler à un administrateur
    Commentaire de taoufikovic90 le 19/06/2007 12:26:16

    bonjour monsieur j'ai une question à vous poser est ce que c'est possible de se connecter à 2 bases de données? j'ai crée deux methodes de connections et quand je férme la premiè-re pour ouvrir la 2eme ça marche pas merci

  • signaler à un administrateur
    Commentaire de gogomanu le 08/07/2007 19:40:29

    Merci beaucoup je débute en Java et c'est grace à ton exemple complet (classe + JSP) que j'ai enfin réussi à me connecter à une base de données !
    Super!
    Donc je vais enfin pouvoir commencer les choses sérieuses en Java !

  • signaler à un administrateur
    Commentaire de GITOS le 27/01/2008 15:26:39

    bonjour
    je voudrais savoir comment etablir une connection Base de données entre Eclipse ( JSP) et SQL server 2005 , a l'aide de Hibernate j'ai essayé avec beaucoup de pilotes JDBC de SQL server  et Dans le fichier struts-config.xml avec cette chaine de connection:  
    <set-property property="url" value="jdbc:jtds:sqlserver://192.168.1.2:1433;databaseName=base_test;user=sa;password=oussama"/>

    quelqu'un a une idée sur le pilote ideal , et l'url de connection et merci .

Ajouter un commentaire

Pub



Appels d'offres

Creation portail video
Budget : 3 000€
Site de e-commerce
Budget : 5 000€
Demande de devis pour ...
Budget : 7 000€

CalendriCode

Juillet 2008
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

VS Express FR Gratuit !

VS Express en français et 100% gratuit !

Boutique

Boutique de goodies CodeS-SourceS