内容简介:http://stackoverflow.com/questions/2464535/preparing-a-mysql-insert-update-statement-with-default-values
引用MySQL INSERT手册 – 同样适用于UPDATE:
Use the keyword DEFAULT to set a column explicitly to its default value. This makes it easier to write INSERT statements that assign values to all but a few columns, because it enables you to avoid writing an incomplete VALUES list that does not include a value for each column in the table. Otherwise, you would have to write out the list of column names corresponding to each value in the VALUES list.
所以简而言之,如果我写
INSERT INTO table1 (column1,column2) values ('value1',DEFAULT);
一个新的行,column2被设置为其默认值 – 无论它是什么 – 被插入.
但是,如果我在 PHP 中准备和执行语句:
$statement = $pdoObject-> prepare("INSERT INTO table1 (column1,column2) values (?,?)"); $statement->execute(array('value1','DEFAULT'));
新行将包含“DEFAULT”作为其文本值 – 如果列能够存储文本值.
现在我已经写了一个PDO的抽象层(我需要它),并解决这个问题我正在考虑介绍一个
const DEFAULT_VALUE = "randomstring";
所以我可以执行这样的语句:
$statement->execute(array('value1',mysql::DEFAULT_VALUE));
然后在做绑定的方法中,我将通过发送绑定的值,如果有些等于self :: DEFAULT_VALUE,则相应地执行.
我很确定有一个更好的方式来做到这一点.有人遇到类似情况吗?
例如.
$pdo = new PDO("mysql:host=localhost;dbname=test", 'localonly', 'localonly'); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $pdo->exec(" CREATE TEMPORARY TABLE foo ( id int auto_increment, x int NOT NULL DEFAULT 99, y DATETIME NOT NULL DEFAULT '2010-03-17 01:00:00', z varchar(64) NOT NULL DEFAULT 'abc', primary key(id) ) "); $stmt = $pdo->prepare(' INSERT INTO foo (x,y,z) VALUES ( Coalesce(:x, Default(x)), Coalesce(:y, Default(y)), Coalesce(:z, Default(z)) ) '); $stmt->bindParam(':x', $x); $stmt->bindParam(':y', $y); $stmt->bindParam(':z', $z); $testdata = array( array(null, null, null), array(1, null, 'lalala'), array(null, '2009-12-24 18:00:00', null) ); foreach($testdata as $row) { list($x,$y,$z) = $row; $stmt->execute(); } unset($stmt); foreach( $pdo->query('SELECT id,x,y,z FROM foo', PDO::FETCH_NUM) as $row) { echo join(', ', $row), "\n"; }
版画
1, 99, 2010-03-17 01:00:00, abc 2, 1, 2010-03-17 01:00:00, lalala 3, 99, 2009-12-24 18:00:00, abc
http://stackoverflow.com/questions/2464535/preparing-a-mysql-insert-update-statement-with-default-values
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- php – Laravel:一般错误:1615准备好的声明需要重新准备
- 详解Openstack环境准备
- 深度有趣 | 02 准备工作
- 2019 面试准备 - 图片
- 如何准备JS迁移
- GraphEngine的开发环境准备
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据压缩导论(第4版)
[美] Khalid Sayood / 贾洪峰 / 人民邮电出版社 / 2014-1 / 129.00
数据压缩已经成为信息革命的一门支撑技术,这场革命已经改变了我们的生活,而在此过程中,数据压缩也变得几乎无处不在。从MP3播放器到智能手机,再到数字电视和数字电影,数据压缩几乎成了所有信息技术的必备要素。 近年来,以大数据为标志的互联网技术高歌猛进。数据规模大、产生速度快、来源多样等特性,导致数据存储和处理都前所未有地复杂。《数据压缩导论(第4版)》作为迄今为止数据压缩领域最全面而深入的著作,......一起来看看 《数据压缩导论(第4版)》 这本书的介绍吧!