php检测表 没有创建,php - 检查SQL Server 2017中是否存在$ tablename,如果不存在则创建表$ tablename - SO中文参考 - www.soinside.com...

在尝试用PHP检查并根据需要在SQLServer2017中创建表时,遇到'Invalid column name'错误。当尝试使用IF EXISTS或OBJECT_ID函数检查表是否存在时,代码无法正确识别用户输入的表名$tablename,导致创建表的尝试失败。直接创建表而不进行检查则可以成功。寻求解决方案。
摘要由CSDN通过智能技术生成

我想检查SQL Server 2017表$ tablename(由用户以PHP形式输入):try {

$dothis = "

IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = N$tablename)

CREATE TABLE $tablename ( id int IDENTITY (1,1), Name text, GeomCol1 geometry, GeomCol2 AS GeomCol1.STAsText() )";

$tbl = $pdo->exec($dothis);

} catch(PDOException $e) {

echo "Error: ".$e->getMessage();

}

但是我总是遇到相同的错误:SQLSTATE[42S22]: [Microsoft][ODBC Driver 17 for SQL Server][SQL Server]Invalid column name 'NNewTable'.

也是:try {

$dothis = "

IF OBJECT_ID ( $tablename, 'U' ) IS NULL

BEGIN

CREATE TABLE $tablename ( id int IDENTITY (1,1), Name text, GeomCol1 geometry, GeomCol2 AS GeomCol1.STAsText() )

END";

$tbl = $pdo->exec($dothis);

错误:SQLSTATE[42S22]: [Microsoft][ODBC Driver 17 for SQL Server][SQL Server]Invalid column name 'NewTable'.

如果不检查表是否首先存在,创建表就没问题:try {

$dothis = "

CREATE TABLE $tablename ( id int IDENTITY (1,1), Name text, GeomCol1 geometry, GeomCol2 AS GeomCol1.STAsText() )";

$tbl = $pdo->exec($dothis);

} catch(PDOException $e) {

echo "Error: ".$e->getMessage();

}

没有错误,它将创建名称为$ tablename的表

不幸的是,每次我尝试使用$ tablename变量来检查表是否存在时,它都会返回错误。我希望有人可以提供帮助。

我想检查SQL Server 2017表$ tablename(由用户以PHP形式输入):试试{$ dothis =“如果存在(选择* FROM INFORMATION_SCHEMA.TABLES ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值