IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MS SQL Server Discussion :

[SQL Server 2000] Delete et alias


Sujet :

MS SQL Server

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 42
    Par défaut [SQL Server 2000] Delete et alias
    Bonjour,

    j'utilise à l'heure actuelle un framework propriétaire Java de requetage sur une base de données. Ce framework a été optimisé pour Oracle. Récemment, nous commençons à utiliser ce framework pour se connecter à des bases SQL Server. Mais là, j'ai une question sur les DELETE

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete from maTable t0 where t0.idTable=1;
    Cette instruction me renvoit l'erreur suivante :

    [Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]Ligne 1 : syntaxe incorrecte vers 't0'.
    Est-ce qu'il ne faut absolument pas utiliser d'alias dans un DELETE :

    Merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 227
    Billets dans le blog
    25
    Par défaut
    Du moment que vous n'utilisez qu'une table, ou est l'intérêt ? Dans ce cas effectivement, le T-SQL réagit comme cité.
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 42
    Par défaut
    C'est simplement le principe du framework. Une table a toujours un alias. Peu importe où elle se trouve.

    J'imagine du coup que pour le update, c'est la même punition ...

    Cependant, comment réaliser ce genre de requête sans ambiguïté

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    DELETE FROM table1
    WHERE id in (select id from table2 where cle_etr = cle_etr);
    avec cle_etr venant de table1 et cle_etr venant de table2 (le même nom quoi ...)

    Ca peut devenir vite foulli ...

  4. #4
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 227
    Billets dans le blog
    25
    Par défaut
    En utilisant quelque chose de bien simple que seul le T-SQL sait faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    DELETE table1 T1
    FROM table2 T2 
    WHERE T1.id = T2.id 
    AND T1.cle_etr = T2cle_etr
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 990
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 990
    Billets dans le blog
    6
    Par défaut
    Votre framework a été élaboré par un bidouilleur qui ne connais pas le langage SQL. SQL est un langage normalisé et il est bien précisé que les tables cibles des ordres de mise à jour (INSERT, DELETE, UPDATE) ne peuvent en aucun cas être aliassées. En effet il ne doit y avoir aucune ambiguité sur la table à impacter, c'est pourquoi il est interdit d'utiliser un alias.

    Ce n'est pas parce que certains SGBDR font n'importe quoi en la matière (Oracle en particulier) qu'il faut les prendre pour modèle !

    SQL Server respecte assez bien la norme SQL. Oracle ne la respecte que très peu !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  6. #6
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 227
    Billets dans le blog
    25
    Par défaut
    Citation Envoyé par SQLpro
    Ce n'est pas parce que certains SGBDR font n'importe quoi en la matière (Oracle en particulier) qu'il faut les prendre pour modèle !

    SQL Server respecte assez bien la norme SQL. Oracle ne la respecte que très peu !

    A +
    SQLPro, te serait-il possible d'expliciter un peu ? cette affirmation me semble quelque peu obsolète en rapport avec les versions actuelles de ces SGBDR.
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  7. #7
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 990
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 990
    Billets dans le blog
    6
    Par défaut
    je comprends pas bien ce que tu veut dire ...

    exemple sous MS SQL Server :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    CREATE TABLE T_TEST_UPDATE 
    (COL1 INT)
    GO
     
    INSERT INTO T_TEST_UPDATE VALUES (33)
    GO
     
    1 ligne(s) affectée(s))
     
    UPDATE T_TEST_UPDATE T
    SET    T.COL1 = 44
     
    Serveur : Msg 170, Niveau 15, État 1, Ligne 2
    Ligne 2 : syntaxe incorrecte vers 'T'.
     
     
    UPDATE T_TEST_UPDATE
    SET    COL1 = 44
     
    (1 ligne(s) affectée(s))
     
    UPDATE T_TEST_UPDATE
    SET    COL1 = (SELECT T.COL1 
                   FROM T_TEST_UPDATE T)
     
    (1 ligne(s) affectée(s))
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. Resultat d'une requete DELETE SQL SERVER 2000
    Par Tronic dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 20/12/2006, 13h06
  2. Certification 70-228 sql server 2000
    Par Cotentin dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 20/11/2003, 09h01
  3. Débutant : SQL Server 2000
    Par bd0606 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 27/10/2003, 11h33
  4. Migration de MS SQL 7 vers MS SQL server 2000
    Par jfphan dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 15/10/2003, 11h24
  5. problème de float sur SQL server 2000.
    Par fidji dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 24/07/2003, 14h15

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo