- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将新记录插入 MySQL 数据库,但我正在使用的准备好的语句方法不起作用。我正在使用我找到的查询 here ,看起来应该可以完美地工作,但事实并非如此。我没有收到任何错误。
这是我的表格:
<form name="registration" action="su-sql.php" method="post">
<ul>
<fieldset>
<li><label for="email">Email</label></li>
<li><input type="email" name="email" id="email" required="required" aria-required="true" spellcheck="false" onblur="checkEmail(this.value);" onchange="checkEmail(this.value);"/></li>
<li><label for="password">Password</label></li>
<li><input type="password" name="password" id="password" required="required" aria-required="true" spellcheck="false" onblur="checkPassword(this.value);" onchange="checkPassword(this.value);"/></li>
<li><label for="passconfirm">Confirm Password</label></li>
<li><input type="password" name="passconfirm" id="passconfirm" required="required" aria-required="true" spellcheck="false" onblur="checkPassconfirm(this.value);" onchange="checkPassconfirm(this.value);"/></li>
</fieldset>
<fieldset>
<li><label for="firstname">First Name</label></li>
<li><input type="text" name="firstname" id="firstname" required="required" aria-required="true" onblur="checkFirstname(this.value);" onchange="checkFirstname(this.value);"/></li>
<li><label for="lastname">Last Name</label></li>
<li><input type="text" name="lastname" id="lastname" required="required" aria-required="true" onblur="checkLastname(this.value);" onchange="checkLastname(this.value);"/></li>
<li><label for="country">Country</label></li>
<li>
<select name="country" id="country" required="required" aria-required="true" onblur="checkCountry(this.value);" onchange="checkCountry(this.value);">
<option selected value="" class="option" id="choose">Choose your Country</option>
<?php
$countries = array('Afghanistan','Akrotiri','Albania','Algeria','American Samoa','Andorra','Angola','Anguilla','Antarctica','Antigua and Barbuda',
'Argentina','Armenia','Aruba','Ashmore and Cartier Islands','Australia','Austria','Azerbaijan','Bahamas, The','Bahrain','Bangladesh','Barbados',
'Bassas da India','Belarus','Belgium','Belize','Benin','Bermuda','Bhutan','Bolivia','Bosnia and Herzegovina','Botswana','Bouvet Island','Brazil',
'British Indian Ocean Territory','British Virgin Islands','Brunei','Bulgaria','Burkina Faso','Burma','Burundi','Cambodia','Cameroon','Canada',
'Cape Verde','Cayman Islands','Central African Republic','Chad','Chile','China','Christmas Island','Clipperton Island','Cocos (Keeling) Islands',
'Colombia','Comoros','Congo, Democratic Republic of the','Congo, Republic of the','Cook Islands','Coral Sea Islands','Costa Rica','Cote d\'Ivoire',
'Croatia','Cuba','Cyprus','Czech Republic','Denmark','Dhekelia','Djibouti','Dominica','Dominican Republic','Ecuador','Egypt','El Salvador','Equatorial Guinea',
'Eritrea','Estonia','Ethiopia','Europa Island','Falkland Islands (Islas Malvinas)','Faroe Islands','Fiji','Finland','France','French Guiana',
'French Polynesia','French Southern and Antarctic Lands','Gabon','Gambia, The','Gaza Strip','Georgia','Germany','Ghana','Gibraltar','Glorioso Islands','Greece',
'Greenland','Grenada','Guadeloupe','Guam','Guatemala','Guernsey','Guinea','Guinea-Bissau','Guyana','Haiti','Heard Island and McDonald Islands',
'Holy See (Vatican City)','Honduras','Hong Kong','Hungary','Iceland','India','Indonesia','Iran','Iraq','Ireland','Isle of Man','Israel','Italy','Jamaica',
'Jan Mayen','Japan','Jersey','Jordan','Juan de Nova Island','Kazakhstan','Kenya','Kiribati','Korea, North','Korea, South','Kuwait','Kyrgyzstan',
'Laos','Latvia','Lebanon','Lesotho','Liberia','Libya','Liechtenstein','Lithuania','Luxembourg','Macau','Macedonia','Madagascar','Malawi','Malaysia',
'Maldives','Mali','Malta','Marshall Islands','Martinique','Mauritania','Mauritius','Mayotte','Mexico','Micronesia, Federated States of','Moldova',
'Monaco','Mongolia','Montserrat','Morocco','Mozambique','Namibia','Nauru','Navassa Island','Nepal','Netherlands','Netherlands Antilles','New Caledonia',
'New Zealand','Nicaragua','Niger','Nigeria','Niue','Norfolk Island','Northern Mariana Islands','Norway','Oman','Pakistan','Palau','Panama','Papua New Guinea',
'Paracel Islands','Paraguay','Peru','Philippines','Pitcairn Islands','Poland','Portugal','Puerto Rico','Qatar','Reunion','Romania','Russia','Rwanda',
'Saint Helena','Saint Kitts and Nevi','Saint Lucia','Saint Pierre and Miquelon','Saint Vincent and the Grenadines','Samoa','San Marino','Sao Tome and Principe',
'Saudi Arabia','Senegal','Serbia and Montenegro','Seychelles','Sierra Leone','Singapore','Slovakia','Slovenia','Solomon Islands','Somalia','South Africa',
'South Georgia and the South Sandwich Islands','Spain','Spratly Islands','Sri Lanka','Sudan','Suriname','Svalbard','Swaziland','Sweden','Switzerland','Syria',
'Taiwan','Tajikistan','Tanzania','Thailand','Timor-Leste','Togo','Tokelau','Tonga','Trinidad and Tobago','Tromelin Island','Tunisia','Turkey','Turkmenistan',
'Turks and Caicos Islands','Tuvalu','Uganda','Ukraine','United Arab Emirates','United Kingdom','United States','Uruguay','Uzbekistan','Vanuatu','Venezuela',
'Vietnam','Virgin Islands','Wake Island','Wallis and Futuna','West Bank','Western Sahara','Yemen','Zambia','Zimbabwe');
foreach ($countries as $country) {
echo '<option value="'.$country.'" class="option">'.$country.'</option>';
}
?>
</select>
<div class="clear"></div>
</li>
<li><label for="gender">Gender</label></li>
<li>
<input checked type="radio" name="gender" value="male" required="required" aria-required="true" onchange="checkGender(this.value);"> Male
<input type="radio" name="gender" value="female" required="required" aria-required="true" onchange="checkGender(this.value);"> Female
</li>
<li><input type="submit" value="Submit"/></li>
</fieldset>
</ul>
<div class="clear"></div>
</form>
这是 PHP:
error_reporting(E_ALL);
ini_set('display_errors',1);
$db_host = "localhost";
$db_user = "user";
$db_pass = "pass";
$db_name = "name";
$db = new PDO('mysql:host='.$db_host.';dbname='.$db_name, $db_user, $db_pass);
do {
/*
Generate random number between min and max
min: 1000000000
max: 2147483647
*/
$uid = mt_rand(1000000001,2147483646);
// make sure that uid isn't already being used
$query = $db->prepare("SELECT * FROM `members` WHERE `uid` = :uid");
$query->bindValue(":uid", $uid);
$query->execute();
$user = $query->fetch(PDO::FETCH_ASSOC);
} while ($user['uid'] === $uid);
$fbid = null;
$email = $_POST['email'];
$password = $_POST['password'];
$firstname = $_POST['firstname'];
$lastname = $_POST['lastname'];
$country = $_POST['country'];
$gender = $_POST['gender'];
echo $firstname.' '.$lastname.': '.$uid;
// Using prepared statements almost eliminates the possibility of SQL Injection.
$query = $db->prepare("INSERT INTO `members`(uid, fbid, email, password, firstname, lastname, country, gender)
VALUES(:uid, :fbid, :email, :password, :firstname, :lastname, :country, :gender)");
$query->execute(array(
"uid" => $uid,
"fbid" => $fbid,
"email" => $email,
"password" => $password,
"firstname" => $firstname,
"lastname" => $lastname,
"country" => $country,
"gender" => $gender
));
// get the user's DB entry
$query = $db->prepare("SELECT * FROM `members` WHERE `uid` = :uid");
$query->bindValue(":uid", $uid);
$query->execute();
// Retrieve the results from the database
$user = $query->fetch(PDO::FETCH_ASSOC);
if($user) {
echo '<br/>'.$user['firstname'].' '.$user['lastname'].': '.$user['uid'];
} else {
echo '<br/>No User';
}
页面加载时,它会在第一行显示用户的名字和姓氏以及新生成的 ID 号。第二行显示“无用户”。
请不要介意密码不受保护。我刚刚开始做这件事。
谁能看出问题出在哪里吗?
最佳答案
正如 @Fred-ii 所建议的,我在数据库连接后添加了以下行:
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
当我这样做时,我收到以下错误:
Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'fbid' cannot be null' in /home/ourfilmclub/public_html/build/su-sql.php:68 Stack trace: #0 /home/ourfilmclub/public_html/build/su-sql.php(68): PDOStatement->execute(Array) #1 {main} thrown in /home/ourfilmclub/public_html/build/su-sql.php on line 68
基本上,fbid
列不能为 null
。我将 null
替换为 ''
,现在一切正常。荣誉@Fred-ii-
关于php - PDO INSERT INTO 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29424383/
我正在开发一些用于计费的数据库项目(PHP/MySQL)。 每当创建新账单时,我想生成一个由年、周和增量编号组成的账单编号。我想用触发器来做到这一点。触发器将使用现有的账单编号来查找增量编号,或者从新
我有一个 MySQL 插入,我正在使用 RAND 生成随机 INT 值问题是它不会插入到数据库中,因为该列接受 TINYINT ,如何将输出转换为 TINYINT。代码示例如下: INSERT INT
如果我想从单个插入中保存主键 (mytable_id),我已完成以下操作: CREATE OR REPLACE FUNCTION myfunct(ownerid text) RETURNS void
为了简单起见,假设我有两个表 用户表(id,email) 用户日志表(id, date) 无论 id 被插入到 user 表中,相同的 id 也应该被插入到 user_log 表中,否则事务应该失败。
为了简单起见,假设我有两个表 用户表(id,email) 用户日志表(id, date) 无论 id 被插入到 user 表中,相同的 id 也应该被插入到 user_log 表中,否则事务应该失败。
我知道在触发器中 - 至少对于 SQL Server - 人们永远不应该假设插入的表只有一行,这意味着触发器中这样的 SQL 通常是不好的: select @UserID = ID from inse
我正在使用 bigquery 对象中的方法 tabledata().insertAll 更新行列表。执行后,返回显示没有错误。但是,我的表仍然继续,没有写入任何数据。 可能是权限问题。如果是这样,为什
这是一个扩展 F# Recursive Tree Validation 的问题,我昨天已经很好地回答了。 这个问题涉及在现有树中插入一个 child 。这是我想使用的更新类型: type Name
我有 2 个表:用户和照片(在 mysql 数据库中)。 在这里你可以看到两个表之间的关系 User Photos -------------
我试图同时在不同的表上插入两行。 子查询INSERT INTO的AUTO_INCRMENT或id的值(如果已经存在)应该写入主查询中。 目前我有这个(仅用 3 个值简化),但它不起作用。我想知道是否有
我有一个 900 万行的表,由于其庞大的规模,我正在努力处理所有这些数据。 我想做的是在不覆盖数据的情况下将 IMPORT 一个 CSV 添加到表中。 在我做这样的事情之前; INSERT if no
我正在写新闻并将其插入到我的数据库中,我在 3 年前构建了代码并且运行良好,但我不能再插入了,我不明白为什么: $insert=mysqli_query($co,"INSERT INTO articl
我正在尝试编写一个简单的 INSERT 语句来将新用户添加到数据库中,但它不起作用,这意味着,我尝试插入到表中的数据都没有被插入。几个小时以来,我一直在尝试解决此问题,但没有成功。我尝试编写插入语句的
所以我有这个表格: http://i.imgur.com/vZYssQy.png 现在 ID、First Name、Last Name、DOB、Address、Phone Number 和 Post
在控制台中运行查询(SELECT 语句)时,从数据库检索到的数据以表格格式显示在数据库控制台工具窗口的结果 Pane 中。 我已经搜索过 datagrip Help我只是想知道是否有任何方法可以用于为
每当使用触发器插入行时,我都试图将另一行插入表中,但收到以下错误消息: The target table 'EDDSDBO.Redaction' of the DML statement cannot
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 6 年前。 Improve
我有以下代码片段: $get_data = mysqli_query ($connect, "SELECT * FROM users WHERE username = '$username'");
情况:需要向 SQLite 数据库中插入大量数据。 问题:我们可以使用两个语句来插入数据 - data = [("111", "222", "333"), ("AAA", "BBB", "CCC"),
我的数据库中有一个表 Teacher: TABLE Teacher ( ID CHAR (7) NOT NULL , name
我是一名优秀的程序员,十分优秀!