首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >仅在创建php pdo数据库时运行一次插入查询

仅在创建php pdo数据库时运行一次插入查询
EN

Stack Overflow用户
提问于 2014-09-18 03:25:20
回答 1查看 549关注 0票数 0

来自config.php

代码语言:javascript
复制
<?php 
global $dbh;
$dbname = 'memberdb';


try {
        $dbh = new PDO("mysql:host=localhost", "root", "");
        $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $dbname = "`".str_replace("`","``",$dbname)."`";
        $dbh->query("CREATE DATABASE IF NOT EXISTS $dbname");
        $dbh->query("use $dbname"); 
    $dbh->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
    $sql ="CREATE TABLE IF NOT EXISTS $member ( 
        mem_id int(40) NOT NULL AUTO_INCREMENT PRIMARY KEY,
        username VARCHAR(40) NOT NULL, 
        password VARCHAR(40) NOT NULL);" ;
        $dbh->exec($sql); 
$stmt = $dbh->prepare("INSERT INTO member (username, password) VALUES (?,?)")or die($db->errorInfo());
    $stmt->bindValue(1,"admin1",PDO::PARAM_STR);
    $stmt->bindValue(2,"password1",PDO::PARAM_STR);
    $stmt->execute();
    $stmt->bindValue(1,"admin2",PDO::PARAM_STR);
    $stmt->bindValue(2,"password2",PDO::PARAM_STR);
    $stmt->execute();
    $stmt->bindValue(1,"admin3",PDO::PARAM_STR);
    $stmt->bindValue(2,"password3",PDO::PARAM_STR);
    $stmt->execute();
} catch(PDOException $e) {

}
?>

当用户使用注册按钮注册时,这就是我的新用户的功能。如何使这类函数在创建数据库时只运行一个,并且只运行一个。我需要为每个输入输入定义值,但我还没有改变它。

UPDATE

我使用的代码在我的prob上面仍然是相同的,当我重新加载index.php时,查询再次运行,产生双重entry..what,我想要的是在创建数据库时,查询将运行,加载时不会再次创建数据库,因此我希望查询不再运行,以避免重复输入。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-18 06:48:23

代码语言:javascript
复制
$stmt = $dbh->prepare("SELECT * FROM member") ;
    $stmt->execute();
    $count = $stmt -> rowCount();
    echo $count;
    if( $count == 00 ){
        $stmt = $dbh->prepare("INSERT INTO member (username, password) VALUES (?,?)")or die($db->errorInfo());
        $stmt->bindValue(1,"admin1",PDO::PARAM_STR);
        $stmt->bindValue(2,"password1",PDO::PARAM_STR);
        $stmt->execute();
        $stmt->bindValue(1,"admin2",PDO::PARAM_STR);
        $stmt->bindValue(2,"password2",PDO::PARAM_STR);
        $stmt->execute();
        $stmt->bindValue(1,"admin3",PDO::PARAM_STR);
        $stmt->bindValue(2,"password3",PDO::PARAM_STR);
        $stmt->execute();
    }

我只想再问一个问题,为什么有时计数的回声是3,有时它的33,它类似的查询运行两次,请清除这个out...this工作了,但是也许这里可能有不正确的逻辑,请随意编辑,使它完美。

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

https://stackoverflow.com/questions/25903684

复制
相关文章

相似问题

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