草庐IT

PDO-ODBC

全部标签

php - 将日期参数绑定(bind)到准备好的语句时出错——将 PHP PDO/ODBC 与 SQL Server 一起使用

我有一个与ODBC(v2000.86.359.00)连接到SQLServer(v8.00.2039SP4标准版)数据库的pdo连接。这个有效:$id=486;$duedate='June27,2012';$query="INSERTintoAssetHistory(AssetID,DateDue)Values($id,$duedate);";$noParams=$db->exec($query);$db->query($query);但是如果我尝试使用这样的准备好的语句:$sql='INSERTintoAssetHistory(AssetID,DateDue)Values(:id,:d

PHP Firebird API : php_interbase or PDO?

2年来,我们一直在新脚本中使用PDO来连接我们的MySQL、PostgreSQL和SQLite数据库。我们现在开始一个项目,我们需要读取(可能还有一些简单的更新)一个Firebird2.5数据库文件。我想使用PDO,因为我们已经在使用它,而且它不会是一个过渡。然而PDO_FIREBIRDPECL软件包最后一次更新似乎是在2006年。所以我的问题是:对于一个新项目,使用PDOFirebird驱动程序还是使用php_interbaseAPI更好?IE。PDOFirebird驱动程序生产值得吗? 最佳答案 如果您从PHP的主存储库使用PD

PHP PDO ODBC - 数据类型在等于运算符中不兼容

我似乎无法让带有参数的简单WHERE子句起作用,我不断收到一条错误消息:[Microsoft][ODBCSQLServerDriver][SQLServer]Thedatatypesvarchar(max)andtextareincompatibleintheequaltooperator.(SQLExecute[402]atext\pdo_odbc\odbc_stmt.c:254)我已经以多种不同的方式尝试过这个查询,例如未命名:$query=$DBH->prepare("SELECTTOP1*FROMbksb_ResourcesWHEREResourceType=?");$quer

php - 检查 PDO 中的 session ID 是否为 ISSET

我正在切换到PDO准备好的语句,但我在获取和使用sessionID的代码中遇到了问题。当客户注册时,session_id设置为等于user_id(自动递增),并且在用户返回时以相同方式设置session_id。这在切换到PDO之前工作正常,但现在session_id在任何后续页面上都无法识别(它正在将“user_id”视为null)我需要切换到使用PDOsession处理程序,还是有办法继续使用我熟悉的方法?mysql-这是我用来设置sessionID的代码(正常工作)://Statementsdefining$user_name,$passwordand$hashedPassword

php - MSSQL WHERE 子句中的 CASE - odbc 错误

在我的PHPWeb应用程序中,我试图完善逻辑,即用户定义的值组装一个Transact-SQL查询以过滤该值。然后使用ODBC驱动程序执行查询。复杂的是过滤只会在派生字段上进行。除非派生字段是使用CASE表达式创建的字段,否则这绝对可以正常工作。因此,例如,我有一个派生字段,如下所示:CASEWHEN[text_result]ISNOTNULLTHEN[text_result]ELSECASEWHEN[last_event]=1THEN'processed'ELSE'unprocessed'ENDEND如果我尝试使用值“未处理”来过滤它,那么最终组合的查询显然类似于以下内容:SELECT

php - 使用 PHP -> ODBC -> MS SQL 插入 Unicode 字符?

我有以下代码:$sql="updatetbl_testsetcategory=N'resumé';echo$sql;$rs=odbc_exec($conn,$sql);其中$conn是到MSSQL服务器的DSNODBC连接。问题似乎是PHP和MySQL(也许是ODBC?)之间的某个地方unicode字符被转换为垃圾。如果我将echo中的内容直接复制粘贴到EnterpriseManager中,它会很好地插入到MSSQL中。但是,如果我运行代码,它总是以resumé的形式进入MSSSQL。知道我在这里缺少什么吗? 最佳答案 问题不在于O

php - 在涉及 PDO 事务的嵌套原子操作方面需要帮助

我有两个可以独立使用的不同模块,但是Module2依赖于Module1。模块2有一个操作需要是原子的,它调用模块1中的一个操作也需要是原子的。假设我已将PDO::ATTR_ERRMODE设置为PDO:ERRMODE_EXCEPTION,以下高度通用化和截断的代码会产生以下结果:PHPfatalerror:未捕获的异常“PDOException”和消息“已经有一个事件事务”模块1:pdo->beginTransaction();try{$stmt=$this->pdo->prepare(...);...$this->pdo->commit();}catch(Exception$ex){$

php - FileMaker 11 PHP 和 ODBC 换行/回车

我正在使用ODBC连接连接到FileMakerPro11Server。我正在从eBayAPI导入一些信息。当我从ebay收到地址时,它包含两个字段address1和address2。在FileMaker数据库中,我们只有一个地址字段。我试图用PHP用换行符或回车符分隔两个地址,但它似乎从来没有用过。我会尝试插入:"$var1\n$var2"并且FileMaker会将\n读取为普通文本。\r也一样。我也试过设置字符串:也没有成功。我还尝试了我阅读的用于换行符的饼图符号,但它不能以这种方式工作。所以基本上..我怎样才能插入filemaker可以使用phppdo和odbc理解的换行符?

php - PDO PARAM_STR 和长度

我不明白PDOPARAM_*语句中的长度选项。长度是否表示所需字符的数量,还是最大值?例子:$sth->bindParam(2,$color,PDO::PARAM_STR,12);这需要12个字符,还是限制为12个字符?或者,我是否完全误解了这是在做什么? 最佳答案 它表示您希望在输出参数中接收多少数据,服务器不会发送超过此数量的数据。因此,要回答您的问题,这是一个限制而非要求。 关于php-PDOPARAM_STR和长度,我们在StackOverflow上找到一个类似的问题:

php - 制作用于 Hook PDO 查询的 databaseDo() 函数

所以我开始了thistutorial作为PHPPDO的介绍。到目前为止,我只处理过基本的mysql_*类型查询。我注意到,在整个教程中,connect->doaction->disconnect模式不断重复,只有doaction部分发生了变化。在现实世界中,通过创建一个可以将查询传递到其中的函数来消除重复是否是个好主意?例如:处理查询的函数:getMessage();}?>然后,假设我想执行PDO教程第一个示例中的操作,我会这样设置:exec($query);echo$exec;};//PerformactiondatabaseDo($insert);?>$dbh的范围我使用$dbh作