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

  • Post author:
  • Post category:mysql


写代码时,需要给实体类赋值,然后再进行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;



版权声明:本文为ouyongke原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。