草庐IT

PDO_ODBC

全部标签

mysql - 数据库错误 : [Microsoft][ODBC Driver Manager] Data source name not found and no default driver specified

我正在运行SMSEnablerWindows7环境下的软件。收到消息时,数据库未更新并给出错误。Databaseerror:[Microsoft][ODBCDriverManager]Datasourcenamenotfoundandnodefaultdriverspecified我还在ControlPanel\AllControlPanelItems\AdministrativeTools>DataSources(ODBC)>UserDSN中添加了必填字段我正在使用MySQL。 最佳答案 好的......如果测试连接成功而你的应用

php - PDO fetchall() 性能注意事项?

在阅读了一些关于PHP的PDOfetchall()函数对性能影响的文章后,我很好奇是否有另一种方法可以在不调用fetchall().解释一下,大多数人都同意fetchall()往往是资源密集型的。就我而言,我认为这不会是一个太大的问题。是的,我必须从我的数据库中提取整个表并将其显示给用户,但它最多大约有100行;我认为这不会成为问题。但假设,如果我需要提取100,000行,什么是更优化的解决方案? 最佳答案 假设,如果您需要在单个响应中输出所有100,000行,您应该将PDO::MYSQL_ATTR_USE_BUFFERED_QUE

php - 使用 PDO 向表中插入大量变量

我有一个包含大约25个输入字段的大表单。我试图将它们插入到我的表中,而我知道的唯一方法是使用以下...$count=$dbh->exec("INSERTINTOdirectory(field1,field2)VALUES(':value1',':value2')");因为我有这么多的帖子变量,有没有比在我的查询中输入每个人更好的方法呢? 最佳答案 动态准备好的查询您可以从$_POST数组动态构建查询:但是,永远不要相信用户输入,这意味着您不能相信$_POST中的数据会包含有效的列名。1。清理帖子数据您可以定义一个列入白名单的列名数组

php - MySQL 更新查询 - 竞争条件和行锁定会遵守 'where' 条件吗? (php, PDO, MySQL, InnoDB)

我正在尝试建立一个先到先得的模型销售页面。我们有n个相同类型的项目。我们希望将这n个项目分配给提出请求的前n个用户。每个项目对应一个数据库行。当用户按下购买按钮时,系统会尝试查找尚未售出的条目(reservationCompleted=FALSE)并更新用户ID并设置reservationCompleted为真。由于我使用的数据库引擎是InnoDB,我知道有一个内部锁定机制不允许两个进程在同一行上同时进行更新。我的问题是,如果我使用的语句如下,如果两个请求同时到达,这是否会导致不同的用户被分配到同一行?$query="UPDATEavailable_itemsSETassignedPh

php - PDO - 使用表前缀

我喜欢为我的表添加前缀,以防我需要将应用程序安装到只有一个数据库的主机上。我想知道是否有一种使用PDO类处理表前缀的简单方法?目前,我不得不覆盖我自己的数据库中的每个方法,将%p替换为前缀,然后调用super方法。它可以工作,但它并不漂亮! 最佳答案 扩展PDO类可能是最好的选择。classMyPDOextendsPDO{protected$_table_prefix;protected$_table_suffix;publicfunction__construct($dsn,$user=null,$password=null,$d

php - PDO PHP bindValue 不起作用

我知道这个问题已经被问过1000次了,但出于某种原因我继续用头撞墙..这个有效:$sql='SELECTa.eventCode,a.eventTime,a.teamCode,a.playerCode,b.lastName,b.firstName,b.number,a.xCoord,a.yCoord,a.id';$sql=$sql.'FROMeventsa,playersb';$sql=$sql.'WHEREa.regGUIDin('.$regGUID.')and';$sql=$sql.'a.playerCode=b.playerCodeanda.gameCode="'.$game.'"

php - PDO::commit() 成功或失败

PHPPDO::commit()文档指出该方法在成功时返回TRUE,在失败时返回FALSE。这是指beginTransaction()和commit()之间的语句执行成功还是失败?例如,来自文档:$dbh->beginTransaction();$sql='INSERTINTOfruit(name,colour,calories)VALUES(?,?,?)';$sth=$dbh->prepare($sql);foreach($fruitsas$fruit){$sth->execute([$fruit->name,$fruit->colour,$fruit->calories,]);}$

php - "PDO exception: php_network_getaddresses: getaddrinfo failed"更改 DNS 解析器后,数据库在 AWS 上运行

在我们的Laravel5.2应用程序中,我们有一个在AWS上运行的数据库设置,使用多个读取服务器(和多个数据库连接)。晚上,我们将所有网络服务器的DNS解析器更改为GoogleDNS(8.8.8.8和8.8.4.4)。然后,服务器开始吐出这些:PDOException:Exception'PDOException'withmessage'SQLSTATE[HY000][2002]php_network_getaddresses:getaddrinfofailed:Nameorservicenotknown'in/home/forge/studydrive.net/releases/20

PHP、PDO、UTF8 和 MySQL 不玩球

关于UTF-8字符,我真的很努力地试图让PHP通过PDO与MySQL一起玩。我使用php--version得到以下信息:PHP5.3.6(cli)(built:Apr19201113:21:12)Copyright(c)1997-2011ThePHPGroupZendEnginev2.3.0,Copyright(c)1998-2011ZendTechnologies这是来自mysqlcli的欢迎消息:Serverversion:5.1.57Sourcedistribution我将此作为我的数据库连接代码:try{$dbh=newPDO('mysql:host='.$server.';d

php - 在 PDO 查询上设置 group_concat_max_len

我有以下查询:$cases=$conn->prepare("SELECTGROUP_CONCAT(textSEPARATOR'|')astexts,yearFROMcasesGROUPBYyearORDERBYanoDESC");$cases->execute();$cases_result=$cases->fetchAll(PDO::FETCH_OBJ);但有些文字显示不完整所以我必须改变group_concat_max_len的值。我做了如下:mysql_query("SETgroup_concat_max_len=2048");但是不知道如何使用PDO