Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Analinee3

ERROR: syntax error at or near "PRIMARY"

Recommended Posts

Fiz o mapeamento da atividade e   Fiz o código, mas notei q da erro  bem próximo as chaves. Sou iniciante, não tenho noção do erro , como o q é ou que pode ser.agradeço a ajuda!

 

CREATE TABLE CLIENTE(
cod_cliente INTEGER NOT NULL,
nome_cliente VARCHAR(30) NOT NULL,
num_pedido  INTEGER,
PRIMARY KEY(COD_CLIENTE)
);

 CREATE TABLE TELEFONE (
 cod_cliente  INTEGER NOT NULL,
 telefone_fixo  VARCHAR (10),
 telefone_celular  VARCHAR (10),

 FOREIGN KEY ( COD_CLIENTE)
  REFERENCES  CLIENTE  (COD_CLIENTE)
 PRIMARY KEY ( COD_CLIENTE)
   REFERENCES CLIENTE (COD_CLIENTE)

  ); 

  CREATE TABLE EMAIL_CLIENTE (
   cod_cliente     INTEGER NOT NULL,
  email_cliente,  VARCHAR (30),
   email2_cliente VARCHAR (30),

   FOREIGN KEY ( COD_CLIENTE)
  REFERENCES  CLIENTE  ( COD_CLIENTE)
 PRIMARY KEY ( COD_CLIENTE)
   REFERENCES CLIENTE (COD_CLIENTE)
   );

   CREATE TABLE VENDA (
   num_pedido      INTEGER,
   dt_pedido     TIMESTAMP,
   cod_pedido   INTEGER,

   PRIMARY KEY (NUM_PEDIDO) 
   FOREIGN KEY (COD_PRODUTO)
     REFERENCES  PRODUTO (COD_PRODUTO);
   
  CREATE TABLE VENDA_CONTEM(
num_pedido        INTEGER,
cod_produto        INTEGER,
pco_produto      NUMERIC (6,0),
qtd              NUMERIC (6,0),

PRIMARY KEY (NUM_PEDIDO)
REFERENCES  VENDA( NUM_PEDIDO)
FOREIGN KEY ( COD_PRODUTO)
 REFERENCES  PRODUTO ( COD_PRODUTO)
 );

 CREATE TABLE PRODUTO (
 cod_produto      INTEGER,
 nom_produto      VARCHAR (30) NOT NULL,
 est_produto     NUMERIC (6,0),
 pco_produto    NUMERIC (6,0),
 fabricante       VARCHAR (30),

 FOREIGN KEY (NUM_PEDIDO)
  REFERENCES  COMPRA ( NUM_PEDIDO)
  PRIMARY KEY (COD_PRODUTO)
 );


 CREATE TABLE COMPRA (
 num_pedido     INTEGER,
 dta_pedido     TIMESTAMP,
  FOREIGN KEY (NUM_PEDIDO)
  REFERENCES  VENDA (NUM_PEDIDO)
  PRIMARY KEY (NUM_PEDIDO)
   REFERNCES VENDA(NUM_PEDIDO)
   );

   CREATE TABLE FORNECEDOR (
   cod_fornecedor         INTEGER,
   nom_fornecedor     VARCHAR (30) NOTT NULL,
   rua_local             VARCHAR (30),
   numero_local      VARCHAR (30),

   PRIMARY KEY ( COD_FORNECEDOR)
   );

CREATE TABLE TELEFONE_FORNECEDOR(
cod_fornecedor   INTEGER,
telefone1   VARCHAR (10),
telefone2      VARCHAR (10),

FOREIGN KEY ( COD_FORNECEDOR)
  REFERENCES FORNECEDOR ( COD_FORNECEDOR)
PRIMARY  KEY ( COD_FORNECEDOR)
    REFERENCES  FORNECEDOR ( COD_FORNECEDOR)
    
  );

  CREATE TABLE EMAIL_FORNECEDOR (
cod_fornecedor    INTEGER,
email1_fornecedor  VARCHAR (30),
email2_fornecedor   VARCHAR (30),

FOREIGN KEY (COD_FORNECEDOR)
  REFERENCES FORNECEDOR ( COD_FORNECEDOR)
 PRIMARY  KEY ( COD_FORNECEDOR)
    REFERENCES  FORNECEDOR ( COD_FORNECEDOR)

    );

Screenshot_2019-05-04-12-09-41.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Acho que tem uma vírgula entre as definições da PK e FK.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Segue o exemplo de uma fonte confiável.

 

Rode um "create" por vez.

Compartilhar este post


Link para o post
Compartilhar em outros sites

1. nao existe "primary key... references".
2. algumas colunas estão sendo definidas como primary e foreign key ao mesmo tempo, ex: tabelas telefone e email_cliente. verifique isso, pq uma chave primaria tem que ser unica e nao nula, portanto o cliente será obrigado a ter um telefone e um email e apenas um...

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ckcesar
      Eu tenho uma aplicação no zend com a versão 5.6 e com o postgresql 9.6. Agora eu precisei mudar a versão do meu postgresql para o 16.1, a parte de conexão do bd e consultas sqls funciona perfeitamente, o meu problema está para acessar os meus controllers. Eles não são encontrados em nenhuma rota, quero ver se alguém já passou por esse problema para me ajudar. Obrigado.
    • Por ILR master
      Boa tarde, pessoal.
      Espero que todos estejam bem.
       
      Seguinte:
      Tenho a seguinte consulta:
       
      $usuarios= "SELECT * FROM usuarios";
      $query= mysqli_query($conexao, $usuarios) or die ("Usuário não encontrado");
      $usuario = mysqli_fetch_array($query);
       
      Quero pegar apenas o campo 'nome' da tabela 'usuarios' e colocar todos os resultados da seguinte forma:
       
      $nomes = array("Rafael", "João", "Maria", "Pedro", "Patricia", "Camila");
       
      Agradeço desde já.
      Abs
       
       
    • Por FabianoSouza
      Tenho uma function que precisa receber 02 argumentos.
      Ela funciona se eu aplicar num select qualquer. Mas se eu aplicar num select dinâmico, ocorre erro.
      Veja trecho do meu select.
      ... SET @sql = @sql +', dbo.retornaIco_ItemBloq((SELECT COUNT(*) FROM dbo.tab AS TT2 WHERE TT2.codCategTreina = CTT.id),'+@title+') AS ''resp''' ... No caso, o primeiro argumento da function dbo.retornaIco_ItemBloq é um SELECT COUNT.
      O segundo argumento é uma variável (que está devidamente declarada e definida).
       
      O erro ocorre porque ao executar (chamando EXEC(@sql) ), o SQL entende que o segundo argumento é uma coluna da consulta principal, pois existe uma vírgula antes da variável @title (que é o segundo argumento da function).
      Repito. Se eu aplicar essa function num select normal, funciona normalmente. Porém, preciso que funcione num SQL dinâmico porque é esse é o padrão que estou adotando para o sistema todo.
       
      A function dbo.retornaIco_ItemBloq faz o seguinte:
      1) Recebe o valor do COUNT e da variável @title
      2) Se o COUNT for maior que  Zero, cria uma tag HTML (uma SPAN), define sua title com o valor da variável @title e passa para uma variável
      3) Retorna o HTML que será exibido no resultado da consulta principal
      É super simples.
       
      Há outra forma de chamar a function?
    • Por mr22robot
      Ola caros amigos. 
      Estou com uma dúvida aqui que embora nao tenho achado ainda uma resposta, acredito que haja.
      Estou estudando a tão sonhada linguagem de programação asp.net core mvc. Linguagem essa que demorei 5 anos pra iniciar os estudos rsrs.
      Mas estou agarrado em uma situação. 
      Estou usando como base de dados nos meus estudos um banco Oracle. Que já tem algumas informações nele. Utilizei o SCAFFOLD para criar as classes e o contexto baseado no banco e tabelas existentes. 
      Porem agora na fase das consultas, estou perdido em como utilizar o IN que eu utilizo no oracle; no LINQ.
      Ex: 
      SELECT CODPROD,DESCRICAO FROM PRODUTO WHERE CODPROD IN(1,2,3,4,5,6) Como eu utilizo esse filtro com uma restrição de códigos de produtos? no caso o where codprod in(1,2,3,4,5,6) ?.
      Desde já obrigado pela ajuda.
    • Por Sapinn
      Olá a todos existe alguma maneira de trazer todos os dados de uma tabela menos o maior valor?
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.