首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Postgres中插入到表中

在Postgres中插入到表中
EN

Stack Overflow用户
提问于 2018-10-03 09:52:08
回答 1查看 49关注 0票数 0

我创建了一个页面,将元素插入到php中的数据库中。在乞讨的时候,我开始用mySQL,它工作得很好。然后我迁移到Postgres,所以我遇到了一些问题。我更改代码,不接收错误,但是当我试图将元素插入到db中时,它仍然是空的。

这是我的表Prenotazione的结构

代码语言:javascript
复制
CREATE TABLE public."Prenotazione"
(
  id integer NOT NULL DEFAULT nextval('"Prenotazione_id_seq"'::regclass),
  nominativo character(20),
  email character(20),
  oggetto character(200),
  nominativoi character(200),
  nominativoe character(200),
  emaili character(200),
  emaile character(200),
  data date,
  orario_inizio time without time zone,
  orario_fine time without time zone,
  stanza integer
)

这是我的index.php

代码语言:javascript
复制
<form method="post" action="input.php">
                        <b>&ensp;Richiedente Conferenza:</b><br><br>
                        &ensp;Nominativo:<br>&ensp;<input type="text" name="nominativo" placeholder="Nome Cognome" size="20"><br>
                        &ensp;Email: <br> &ensp;<input type="email" name="email" size="20" placeholder="email"><br>
                        &ensp;Oggetto Conferenza:<br>&ensp;<textarea name="oggetto" rows="5" cols="40" placeholder="Specificare oggetto Videoconferenza"></textarea><br>
                        &ensp;Data: <br>&ensp;<input  type="date" name="data"  ><br>
                        &ensp;Orario Inizio: <br>&ensp;<input type="time" name="orario_inizio" min="09:30:00" max="16:30:00" ><br>
                        &ensp;Orario Fine: <br>&ensp;<input type="time" name="orario_fine" min="10:00:00" max="18:30:00"><br>

                        <br>
                        <b>&ensp;Partecipanti Interni </b>
                        <br>
                        <br>
                <div id="interni">
                    <div id="first">
                        &ensp;Nominativo:<br>&ensp;<textarea name="nominativoi" rows="5" cols="30" placeholder="Nome Cognome;"  ></textarea><br>
                        &ensp;Email:<br>&ensp; <textarea  name="emaili" rows="5" cols="30" placeholder="Inserire Email"></textarea><br> 
                      <br>
                      <br>
                    </div>
                </div>
                        <b>&ensp;Partecipanti Esterni </b>
                <div id="esterni">
                    <div id="first">
                               &ensp;Nominativo:<br>&ensp;<textarea name="nominativoe" rows="5" cols="30" placeholder="Nome Cognome;" ></textarea><br>
                                &ensp;Email:<br>&ensp;<textarea  name="emaile" rows="5" cols="30" placeholder="Inserire Email"></textarea><br> 
                      <br>
                    &ensp;&ensp;<input type="submit" value="Invia" > 
                        </form>

最后是input.php

代码语言:javascript
复制
$checkdata = "SELECT count(*) as prenotato
  FROM Prenotazione
 WHERE data='$data'
   AND NOT ('$newTimeEnd' < orario_inizio OR orario_fine < '$orario_inizio')";

$querycheck = $dbh->prepare($checkdata);
$querycheck->execute();
$prenotato = $querycheck->fetch()[0];
var_dump($prenotato);
if ($prenotato == 0 AND $stanza == 0 ) { 

    $query1 = "INSERT INTO Prenotazione (nominativo,email,data,orario_inizio,orario_fine,oggetto,nominativoi,emaili,nominativoe,emaile,stanza) VALUES ('$nominativo','$email','$data','$orario_inizio','$newTimeEnd','$oggetto','$nominativoi','$emaili','$nominativoe','$emaile',1)";
    var_dump($query1);
    $result1 = $dbh->prepare($query1);
    $result1->execute();
    $rex = 1;
}
else if ($prenotato == 1){
    $query1 = "INSERT INTO Prenotazione (nominativo,email,data,orario_inizio,orario_fine,oggetto,nominativoi,emaili,nominativoe,emaile,stanza) VALUES ('$nominativo','$email','$data','$orario_inizio','$orario_fine','$oggetto','$nominativoi','$emaili','$nominativoe','$emaile',2)";
    $result1 = $dbh->prepare($query1);
    $result1->execute();
    $rex = 1;
}

我贴出了对这个问题感兴趣的部分。谢谢

var_dump的结果是:

空字符串(269)“插入Prenotazione (名称、电子邮件、数据、orario_inizio、orario_fine、oggetto、nominativoi、emaili、nominativoe、emaile、stanza)值(”用户名“、”电子邮件@email.com“、”2018-10-03“、”09:30“、”12:30“、”object“、”username1“、”email1@email1.com“、”username2“、”email2@email2.com“,1)”

EN

回答 1

Stack Overflow用户

发布于 2018-10-03 16:15:13

问题在于您的表名是双引号。不要使用双引号,也不要在每个请求中使用它们。

您可以在这里验证您的代码:

http://rextester.com/VIEH75483

另外,请参阅更多信息:Omitting the double quote to do query on PostgreSQL

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52624326

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档