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

Langage SQL Discussion :

Problème de migration de MySQL vers SQL Server


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de sovo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mars 2004
    Messages
    1 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 389
    Par défaut Problème de migration de MySQL vers SQL Server
    Bonjour a tous.


    J'ai une base de données sous MySQL et je voudrais la faire migrer vers SQL Server, mais je n'arrive pas a convertir le script de création de la BD.

    quelqu'un pour un coup de main S'il vous plait ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    CREATE TABLE Personne (
      Id bigint(19) NOT NULL auto_increment,
      Nom varchar(50) default NULL,
      Prenom varchar(50) default NULL,
      idPays bigint(19) default 45,
      PRIMARY KEY  (Id)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1;

  2. #2
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    42
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 42
    Par défaut conversion
    Bonjour,
    Au niveau de SQL, pour créer un champ auto-incrément on utilise IDENTITY(valeurdepart,pas) , et pour les int, on spécifie pas la largeur de la colonne.
    Ton code sera comme suit après migration :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    CREATE TABLE Personne (
      Id bigint NOT NULL IDENTITY(1,1),
      Nom varchar(50) DEFAULT NULL,
      Prenom varchar(50) DEFAULT NULL,
      idPays bigint DEFAULT 45,
      PRIMARY KEY  (Id)
    )
    Cordialement

  3. #3
    Membre Expert
    Avatar de sovo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mars 2004
    Messages
    1 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 389
    Par défaut
    le Default ne passe pas. j'avais deja essaye cette requette.

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    bonjour
    Citation Envoyé par sovo Voir le message
    le Default ne passe pas. j'avais deja essaye cette requette.
    La syntaxe est pourtant correcte, même si les DEFAULT NULL sont inutiles
    Il ne vous donne aucune message d'erreur ?

  5. #5
    Membre Expert
    Avatar de sovo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mars 2004
    Messages
    1 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2004
    Messages : 1 389
    Par défaut
    @CinePhil : choix presque imposse, mais je suis d'accord avec toi sur les remarques.

    @aieuuuuuuu : le message d'erreur ressemble a ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg 102, Level 15, State 1, Line 24
    Incorrect syntax near ','.

  6. #6
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Citation Envoyé par sovo Voir le message
    @aieuuuuuuu : le message d'erreur ressemble a ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Msg 102, Level 15, State 1, Line 24
    Incorrect syntax near ','.

    Alors montrez nous la ligne 24, et même toutes les lignes...
    Avec le message d'erreur et les lignes de code qui le génèrent, c'est quand même plus simple pour trouver

  7. #7
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Par ailleurs, je vous conseille de nommer vos contraintes, sinon SQL Sever leur donnera un nom... différent pour chaque serveur.
    Il sera plus compliqué de les modifier ensuite.

    Notez qu'il faudrait aussi declarer la contrainte referentielle sur le pays (a adapter selon le nom de votre table des pays)


    En reprenant les remarques de CinePhil, on arrive à quelque chose comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    CREATE TABLE Personne (
      Id		INT			NOT NULL IDENTITY(1,1),
      Nom		varchar(50) ,
      Prenom	varchar(50) ,
      idPays	int 
    			CONSTRAINT DF_Personne_Pays DEFAULT 45
      ,
      CONSTRAINT PK_Personne PRIMARY KEY  (Id)
      ,
      CONSTRAINT FK_PRESONNE_PAYS FOREIGN KEY idPays REFERENCES PAYS(id)
    )
    Pour ce qui est du INT vs BIGINT :
    certains diront que sur un serveur 64 bits, le traitement des BIGINT est plus rapide que le traitement des INT, d'autres diront que ça prend deux fois plus de place et donc occupe inutilement le cache...
    Personnellement, je reste sur la bonne vieille méthode : le type le plus petit correspondant au besoin : par exemple pour les pays, un tinyint pourrait suffire...

  8. #8
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 815
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 815
    Billets dans le blog
    14
    Par défaut
    En dehors des syntaxes légèrement différentes, tu pourrais en profiter pour réviser les types des colonnes !
    Un bigint pour le pays alors qu'il n'y en a qu'environ 200 sur Terre, c'est très exagéré, sauf si tu es un extraterrestre et que tu références toute la galaxie !
    Même pour l'identifiant de la personne, ça m'étonnerait que tu enregistres toute la population mondiale pour justifier l'emploi d'un bigint !

    Et autoriser une colonne à NULL, c'est mal !
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

Discussions similaires

  1. migration de mysql vers sql server
    Par zikog dans le forum MS SQL Server
    Réponses: 9
    Dernier message: 09/09/2011, 16h38
  2. Réponses: 6
    Dernier message: 26/01/2010, 17h57
  3. Réponses: 4
    Dernier message: 21/07/2008, 13h27
  4. Migration de Mysql vers Sql Server
    Par bluecurve dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 06/02/2007, 00h21
  5. Migration d'une base mySQL vers SQL Server
    Par jazziroquai dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 16/03/2006, 08h36

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