gpt4 book ai didi

php - MySQL插入数据问题

转载 作者:行者123 更新时间:2023-11-29 09:19:21 25 4
gpt4 key购买 nike

假设我已经在 MySQL 中创建了一个表,如下所示

CREATE TABLE IF NOT EXISTS `sales` (
`id` smallint(5) unsigned NOT NULL auto_increment,
`client_id` smallint(5) unsigned NOT NULL,
`order_time` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
`sub_total` decimal(8,2) NOT NULL,
`shipping_cost` decimal(8,2) NOT NULL,
`total_cost` decimal(8,2) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=9 ;

--
-- Dumping data for table `sales`
--

如果我为当前表格添加了一个新字段must_fill

 `must_fill` tinyint(1) unsigned NOT NULL,

默认情况下,用户可以向表中插入少于字段数的项目,如下面的脚本所示。

INSERT INTO `sales` (`id`, `client_id`, `order_time`, `sub_total`, `shipping_cost`, `total_cost`) VALUES
(8, 12312, '2007-12-19 01:30:45', 10.75, 3.00, 13.75);

没关系。

但是当用户计划插入新数据时,如何将字段(must_fill)配置为“必须包含数据”字段。

顺便说一句,代码将集成到 PHP 脚本中。

[更新]或者,当用户尝试运行绑定(bind)了某些数据值的 Insert Into 脚本时,我是否可以只编写特殊的 PHP 脚本来判断 must_fill 是否为空?

最佳答案

强制执行这一点很困难,因为 MySQL 从来就不是这样设计的。 MySQL 表中的 NOT NULL 指定仅仅意味着该值永远不会是 NULL,而不是必须提供一个值:MySQL 将找到一个如果省略则默认。但是,您可以提供一个默认值,如果省略了真实的值,这会很烦人;具体使用什么取决于您的应用程序。

我还会查看MySQL Server Modes 。您可能想要启用STRICT_ALL_TABLES,但这是一个相当严格的设置,如果您的应用程序是针对 MySQL 宽松的默认机制进行编程的,那么您的应用程序可能会崩溃。

关于php - MySQL插入数据问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2770314/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com