0

0

PHP增删改查怎么设置默认值_php默认值设置【配置】

雪夜

雪夜

发布时间:2025-12-26 20:01:43

|

745人浏览过

|

来源于php中文网

原创

PHP中设置默认值有五种方法:一、数据库表结构用DEFAULT约束;二、PHP数组用array_merge合并默认值;三、PDO预处理前判断赋默认值;四、MySQLi结合real_escape_string处理;五、Laravel Eloquent模型中定义$attributes。

php增删改查怎么设置默认值_php默认值设置【配置】

在PHP中进行数据库增删改查操作时,为字段设置默认值可确保数据完整性与程序健壮性。以下是针对不同场景设置默认值的具体配置方法:

一、数据库表结构层面设置默认值

通过SQL语句在创建或修改数据表时,为列定义DEFAULT约束,使INSERT操作未显式提供值时自动填充预设值。

1、使用CREATE TABLE语句添加带默认值的字段:
CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50), status TINYINT DEFAULT 1);

2、对已有表添加默认值约束:
ALTER TABLE products MODIFY COLUMN price DECIMAL(10,2) DEFAULT 0.00;

立即学习PHP免费学习笔记(深入)”;

3、插入数据时不指定该字段,数据库将自动使用默认值:
INSERT INTO users (name) VALUES ('Alice');

二、PHP数组初始化时设置默认值

在处理用户输入或配置数据前,预先用array_merge或null合并方式为关联数组补全缺失键及其默认值,避免undefined index警告。

1、定义包含默认值的基准数组:
$defaults = ['page' => 1, 'limit' => 20, 'sort' => 'id', 'order' => 'ASC'];

2、与用户传入参数合并,保留用户值,缺失则取默认:
$params = array_merge($defaults, $_GET);

3、直接访问安全字段:
$currentPage = $params['page']; // 即使$_GET中无page,仍为1

三、PDO预处理语句中绑定默认值

在执行INSERT或UPDATE语句前,检查变量是否为空或未设置,动态替换为预设默认值后再绑定参数,防止空值写入关键字段。

1、判断并赋默认值:
$status = isset($_POST['status']) && in_array($_POST['status'], [0,1,2]) ? (int)$_POST['status'] : 1;

2、准备SQL语句:
$stmt = $pdo->prepare("INSERT INTO articles (title, content, status) VALUES (?, ?, ?)");

3、执行绑定(第三个参数即为默认状态):
$stmt->execute([$title, $content, $status]);

四、MySQLi面向对象方式设置字段默认行为

利用MySQLi的real_escape_string与类型转换结合逻辑判断,在拼接查询字符串前统一处理字段值,确保非空字段始终有合法默认替代。

1、封装默认值映射规则:
$fieldDefaults = ['is_active' => 1, 'created_at' => date('Y-m-d H:i:s')];

2、遍历待插入字段,未提供则取默认:
foreach ($fields as $key => $value) {
  if (!isset($_POST[$key])) {
    $value = $fieldDefaults[$key] ?? null;
  }
  $safeValue = $mysqli->real_escape_string((string)$value);
  $values[] = "'$safeValue';
}

3、构造完整INSERT语句并执行:
$sql = "INSERT INTO logs (action, user_id, created_at) VALUES ($valuesString)";

五、Laravel Eloquent模型中定义默认属性值

在Eloquent模型类中通过$attributes属性数组声明字段默认值,框架在新建模型实例且未显式赋值时自动应用。

1、在模型类中声明默认值:
protected $attributes = [
  'status' => 1,
  'priority' => 0,
  'is_verified' => false
];

2、创建新记录时不设置status字段:
$user = new User();
$user->name = 'Bob';
$user->save(); // status字段将自动写入1

3、也可在迁移文件中同步定义数据库级默认值:
$table->tinyInteger('status')->default(1);

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1715

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1142

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1043

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1228

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 771人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号