这篇文章主要介绍了如何在MySQL 8.0中隐藏字段,小编觉得不错,现在分享给大家,也给大家做个参考,一起跟随小编来看看吧!
基本概念
隐藏字段需要在查询中进行显式引用,否则对查询而言是不可见的.MySQL 8.0.23开始支持隐藏字段,在此之前所有的字段都是可见字段。
考虑以下应用场景,假如一个应用程序使用SELECT *语句访问某个表,并且必需持续不断地进行查询,即使我们为该表增加了一个该应用不需要的新字段时也要求能够正常工作。对于SELECT *查询,星号(*)代表了表中除隐藏字段之外的所有字段,因此我们可以将新加的字段定义为隐藏字段。该隐藏字段对于SELECT *查询是不可见的,因此应用能够继续运行。如果新版本的应用程序需要使用该字段,可以在查询中显式指定。
PS:不推荐使用SELECT *语句查询数据,应该明确指定需要返回的字段。
隐藏字段与DDL语句
默认情况下创建的字段属于可见字段。如果想要显式指定字段的可见性,可以在创建表或者ALTER TABLE语句中为字段的定义指定可见或者看不见的关键字例。如:
CREATE TABLE t1 ( ,小姐:INT, ,j DATE 看不见 ),ENGINE =, InnoDB; ALTER TABLE  t1 ADD COLUMN  k INT 无形的;
如果想要修改某个字段的可见性,同样可以使用可见或者看不见的关键字例。如:
ALTER TABLE t1 CHANGE COLUMN j j DATE 可见; ALTER TABLE  t1 MODIFY COLUMN  j DATE 看不见; ALTER TABLE t1  ALTER COLUMN  j SET 可见;
使用隐藏字段时,需要注意以下事项:
- <李>
一个表至少需要一个可见字段。如果将所有字段都设置为隐藏字段,将会返回错误。
李> <李>隐藏字段支持常见的字段属性:NULL, NOT NULL以及AUTO_INCREMENT等等。
李> <李>计算列(列)生成可以是隐藏字段。
李> <李>索引可以使用隐藏字段,包括主键和唯一索引。虽然一个表至少需要一个可见字段,但是索引定义中可以不包含任何可见字段。
李> <李>删除某个表中的隐藏字段时,同时会从相关索引中删除该字段。
李> <李>外键约束可以基于隐藏字段进行定义,同时外键约束也可以引用隐藏字段。
李> <李>检查约束可以基于隐藏字段进行定义。插入或者更新数据时,如果违反了隐藏字段上的检查约束将会返回错误。
如果使用创建表……像语句复制表结构,将会复制原表中的隐藏字段,而且它们在新表中仍然是隐藏字段。如果使用创建表……选择语句复制表,不会包含隐藏字段,除非显式指定了隐藏字段。尽管如此,即使包含了原表中的隐藏字段,新表中的这些字段将会变成可见字段,例如:
mysql>, CREATE TABLE t1 (col1 , INT, col2 INT 无形的); mysql>, CREATE TABLE  t2 AS SELECT col1,, col2 得到t1; mysql>, SHOW CREATE  TABLE t2 \ G * * * * * * * * * * * * * * * * * * * * * * * * * * *,1只row * * * * * * * * * * * * * * * * * * * * * * * * * * * 表:才能t2 Create 表:,Create TABLE 《终结者2》,( ,‘col1 int DEFAULT 空, ,‘col2 int DEFAULT NULL ),引擎=InnoDB DEFAULT CHARSET=utf8mb4 整理=utf8mb4_0900_ai_ci
如果想要保留这些字段的隐藏属性,可以在创建表之后为它们指定隐藏属性,例如:
mysql>, CREATE TABLE t1 (col1 , INT, col2 INT 无形的); mysql>, CREATE TABLE  t2 (col2 INT 看不见),AS SELECT col1,, col2 得到t1; mysql>, SHOW CREATE  TABLE t2 \ G * * * * * * * * * * * * * * * * * * * * * * * * * * *,1只row * * * * * * * * * * * * * * * * * * * * * * * * * * * 表:才能t2 Create 表:,Create TABLE 《终结者2》,( ,‘col1 int DEFAULT 空, ,‘col2 int DEFAULT NULL /* ! 80023, INVISIBLE */),引擎=InnoDB DEFAULT CHARSET=utf8mb4 整理=utf8mb4_0900_ai_ci
视图可以引用隐藏字段,需要在定义中显式指定这些字段。在视图定义之后修改字段的可见性不会影响视图。
隐藏字段与DML语句
对于选择语句,除非在查询列表中显式指定了隐藏字段,否则查询结构中不会包含隐藏字段。查询列表中的*和tbl_name。*不会包含隐藏字段。自然连接不会包含隐藏字段。