-1

这些是我的表:

create table sender(
    sno varchar(6) not null,
    sfname varchar(15) not null,
    slname varchar(10) not null,
    sphone varchar(10),
    saddress varchar(40) not null,

    constraint pk_sender primary key(sno)
 );


create table courier(
    cno varchar(6),
    cost double precision not null,
    weight double precision not null,
    del_stat varchar(20) not null,
    no_cour int(10),
    sno varchar(6),

    constraint fk_courier foreign key(sno)
    references sender(sno),constraint pk_courier primary key(cno)
 );

这是我的 php 代码:

    <?php
session_start();
$_SESSION['x']=$_POST[sno];
$con=mysqli_connect("localhost","root","project123","project");
// Check connection
if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }
$sql1="insert into sender(sno,sfname,slname,sphone,saddress) values (concat('SN','$_POST[sno]'),'$_POST[sf]','$_POST[sl]','$_POST[sph]','$_POST[sad]')";
$sql2="insert into courier(cno,cost,weight,del_stat,no_cour) values (concat('CN','$_POST[cno]'),'$_POST[cst]','$_POST[wght]','$_POST[del]','$_POST[num]')";

if(!mysqli_query($con,$sql1) && !mysqli_query($con,$sql2))
{
    die('Error: ' . mysqli_error($con));
}




mysqli_close($con);
?>

但我收到错误错误:无法添加或更新子行:外键约束失败(project. courier, CONSTRAINT fk_courierFOREIGN KEY ( sno) REFERENCES sender( sno))

所以请告诉我如何将值插入外键。

4

1 回答 1

0

您似乎没有在子表插入上设置外键值。你的courier表有一个sno VARCHAR(6)引用的列sender.sno VARCHAR(6)吗?所以你必须为它提供价值。为了将两个字段关联为外键,您必须为存在于父相关列上的子列设置有效值。

无论如何,您应该像这样运行这两个查询:

$sno = "SN$_POST[sno]";
$cno = "CN$_POST[cno]";

$sql1="insert into sender(sno,sfname,slname,sphone,saddress) values ('$sno','$_POST[sf]','$_POST[sl]','$_POST[sph]','$_POST[sad]')";

if(mysqli_query($con,$sql1))
{
    $sql2="insert into courier(cno,cost,weight,del_stat,no_cour, sno) values ('$cno','$_POST[cst]','$_POST[wght]','$_POST[del]','$_POST[num]', '$sno')";

    if (mysqli_query($con,$sql2))
    {
        // Success
    }
    else 
    {
        die('Error on query 2: ' . mysqli_error($con));
    }
}
else 
{
    die('Error on query 1: ' . mysqli_error($con));
}

您可以在此处查看如何从auto_increment字段中获取最后插入的 id。如果您不使用某个auto_increment字段,则必须以适合您需要的其他方式选择它。

我希望这有帮助。

更新:我已经更改了这些变量snocno因为您可以避免在查询中连接它。你可以那样做。我意识到你已经拥有了sno价值,所以你不需要在它之后再次查询。该代码现在可以工作了。

于 2013-11-13T14:10:19.630 回答