MySQL和PostgreSQL/pgsql中查询指定表指定字段的默认值

写代码时,需要给实体类赋值,然后再进行Insert或者Update。

Insert时,一些字段完全可以去查询,设计数据库时设置的默认值,而不是在代码里把值写死。

而且在代码中需要逐个给字段赋值,不赋值的字段ORM生成的SQL里真的会给一个NULL值进去,有些ORM就是不能配置Insert时的[忽略字段]。

此时,我们需要去查询这些字段的默认值,然后再给需要用于Insert的实体类赋值。

在MySQL中,查询一个字段的默认值可以这样:

-- 在MySQL中查询tb_user表的login_times字段的默认值
-- 使用前注意测试,返回值无论是字符还是数字,都不会带引号
SELECT DEFAULT(login_times) AS default_value FROM tb_user LIMIT 1;

在PgSQL中,查询一个字段的默认值可以这样:

-- 在PgSQL中查询public模式中、tb_user表的login_times字段的默认值
-- 使用前注意测试,若数字不会带引号,若字符串则会带引号,且后面会跟着
--一串强制类型转换字符,自增字段则是针对指定序列的nextval()函数,注意清理、合理使用。
SELECT column_default AS default_value FROM information_schema.columns 
 WHERE (table_schema, table_name, column_name) = ('public', 'tb_user', 'login_times') LIMIT 1;

SELECT column_default AS default_value FROM information_schema.columns 
 WHERE table_schema='public' AND table_name='tb_user' 
   AND column_name='login_times' LIMIT 1;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值