社区编辑申请
注册/登录
MySQL默认值和约束的查询方法
数据库 MySQL
本文主要介绍关于MySQL默认值和约束的查询方法,下面,我们一起来看。

一、MySQL默认值相关查询

1. 列出 MySQL 数据库中的表默认值

select table_schema as database_name,
table_name,
column_name,
column_default
from information_schema.columns
where column_default is not null
and table_schema not in ('information_schema', 'sys',
'performance_schema','mysql')
-- and table_schema = 'your database name'
order by table_schema,
table_name,
ordinal_position;

说明:

  • database_name - 数据库的名称(模式)
  • table_name - 表的名称
  • column_name - 列的名称
  • column_default - 定义此列默认值的 SQL 表达式

DBA技术分享(五)-mysql默认值和约束的查询方法

2. MySQL数据库默认值汇总

select column_default,
count(distinct concat(col.table_schema, '.', col.table_name)) as tables,
count(column_name) as columns
from information_schema.columns col
join information_schema.tables tab on col.table_schema = tab.table_schema
and col.table_name = tab.table_name
where col.table_schema not in ('sys', 'information_schema',
'mysql', 'performance_schema')
and tab.table_type = 'BASE TABLE'
group by column_default
order by tables desc,
columns desc;

说明:

  • column_default -为没有默认值的列定义默认约束(公式)和NULL
  • tables- 具有此约束的表数(或具有对NULL行没有约束的列的表数)
  • columns - 具有此特定约束的列数(或NULL行没有约束)

DBA技术分享(五)-mysql默认值和约束的查询方法

二、约束

1. 列出了数据库(模式)中的所有不可为空的列

select tab.table_schema as database_name,
tab.table_name,
col.ordinal_position as column_id,
col.column_name,
col.data_type,
case when col.numeric_precision is not null
then col.numeric_precision
else col.character_maximum_length end as max_length,
case when col.datetime_precision is not null
then col.datetime_precision
when col.numeric_scale is not null
then col.numeric_scale
else 0 end as 'precision'
from information_schema.tables as tab
join information_schema.columns as col
on col.table_schema = tab.table_schema
and col.table_name = tab.table_name
and col.is_nullable = 'no'
where tab.table_schema not in ('information_schema', 'sys',
'mysql','performance_schema')
and tab.table_type = 'BASE TABLE'
-- and tab.table_schema = 'database name'
order by tab.table_schema,
tab.table_name,
col.ordinal_position;

注意:如果您需要特定数据库(模式)的信息,请取消注释 where 子句中的条件并提供您的数据库名称。

说明:

  • database_name - 数据库的名称(模式)
  • table_name - 表的名称
  • column_id - 列在表中的位置
  • column_name - 列的名称
  • data_type - 列数据类型
  • max_length - 数据类型的最大长度
  • precision- 数据类型的精度

DBA技术分享(五)-mysql默认值和约束的查询方法

2. 检查 MySQL 数据库中的列是否可为空

select c.table_schema as database_name,
c.table_name,
c.column_name,
case c.is_nullable
when 'NO' then 'not nullable'
when 'YES' then 'is nullable'
end as nullable
from information_schema.columns c
join information_schema.tables t
on c.table_schema = t.table_schema
and c.table_name = t.table_name
where c.table_schema not in ('mysql', 'sys', 'information_schema',
'performance_schema')
and t.table_type = 'BASE TABLE'
-- and t.table_schema = 'database_name' -- put your database name here
order by t.table_schema,
t.table_name,
c.column_name;

说明:

  • database_name - 数据库名称(模式)
  • table_name - 表名
  • column_name - 列名
  • nullable- 列的可空性属性:is nullable- 可以为空,not nullable- 不可为空

DBA技术分享(五)-mysql默认值和约束的查询方法

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2022-06-26 06:32:28

MySQL数据库维护

2022-06-23 11:42:22

MySQL数据库

2022-05-11 09:02:27

Python数据库Excel

2022-05-17 11:06:44

数据库MySQL系统

2022-06-22 09:56:19

PythonMySQL数据库

2022-06-29 09:43:14

SQL优化数据库

2022-06-20 12:00:43

MySQL数据库升级

2022-06-30 10:56:18

字节云数据库存储

2022-06-06 07:35:26

2022-05-30 11:10:04

数据库MySQL系统

2022-05-26 06:05:16

MySQL数据库

2022-06-13 07:36:06

2022-03-16 14:45:18

MySQL慢查询数据库

2022-06-14 08:01:43

数据库MySQL

2022-05-09 15:52:23

MySQL数据库数据库表

2022-04-29 10:27:58

数据库删库MySQL

2022-06-13 14:58:19

系统案例

2022-05-16 15:17:11

区块链安全加密货币

2022-03-15 11:31:17

MySQL日志格式

2022-04-02 10:23:12

MySQL数据库

同话题下的热门内容

一次非常有意思的 SQL 优化经历:从 30248.271s 到 0.001s解决MySQL幻读的终极指南面试突击:说一下MySQL事务隔离级别?为什么MySQL的count()方法这么慢?为什么SQL语句命中索引比不命中索引要快?面试突击:什么情况会导致 MySQL 索引失效?MySQL 索引失效的几种类型以及解决方式DBA技术分享-MySQL外键查询语句

编辑推荐

MySQL集群搭建详解如果对MySQL还停留在这个印象,就out了防止服务器宕机时MySQL数据丢失的几种方案MySQL innodb引擎备份工具XtraBackup之二(数据库全备)MySQL优化: Slave延迟很大的优化方法总结
我收藏的内容
点赞
收藏

51CTO技术栈公众号