栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在mysql中设置文本类型的默认值

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在mysql中设置文本类型的默认值

我已将关于我们的字段的值从非null更改为null

CREATE TABLE IF NOT EXISTS `te` (  `id` int(30) NOT NULL,  `name` text NOT NULL,  `address` text NOT NULL,  `aboutus` text NULL) ENGINE=InnoDB DEFAULT CHARSET=latin1;

这是你的触发器

BEFORE INSERT

CREATE TRIGGER new_insertBEFORE INSERT ON `te`FOR EACH ROW SET NEW.`aboutus` = CASE WHEN NEW.aboutus IS NULL THEN 'Not Updated' ELSE NEW.aboutus END;

插入时不带

aboutus

INSERT INTO `te` (`id`, `name`, `address`) VALUES (1, 'name', 'address') ;

插入

aboutus

INSERT INTO `te` (`id`, `name`, `address`, `aboutus`) VALUES (2, 'name', 'address', 'aboutus') ;

通过传递null插入

aboutus

INSERT INTO `te` (`id`, `name`, `address`, `aboutus`) VALUES (3, 'name', 'address', null) ;

演示版

编辑 至于 @garethD指出了更新方案的情况下,还需要在另一个触发

BEFORE UPDATE
因此,如果空出现在更新那么关于我们应该进行更新
Not Updated

CREATE TRIGGER update_triggerBEFORE UPDATE ON `te`FOR EACH ROW SET NEW.`aboutus` = CASE WHEN NEW.aboutus IS NULL THEN 'Not Updated' ELSE NEW.aboutus END;UPDATE teSET aboutUs = NULL;


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/517353.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号