MySQL 中创建视图设置字段类型

参考:
MySQL 中创建视图设置字段类型

在 MySQL 中创建视图时,不能直接在视图定义中指定新计算字段的数据类型。但是,你可以通过函数调用或其他表达式转换来隐式地确保新字段的类型。

例如,如果你希望在视图中添加一个新的 int 类型的字段,你可以使用 CAST() 函数或 CONVERT() 函数进行类型转换。

这里是一个简单的例子,假设你有一个表 orders,表中有一个 price 字段,你想要创建一个视图,并在视图中包含一个新的 int 类型的字段,该字段代表 price 的整数部分。

sql 复制代码
CREATE VIEW my_view AS
SELECT 
    order_id,
    CAST(price AS SIGNED) AS price_as_int
FROM 
    orders;

在这个示例中:

  • order_id 是从原表中直接选择的字段。
  • price_as_int 是使用 CAST(price AS SIGNED)price 字段转换为 int 类型的新字段。

如果你希望将对某个字段的操作结果转换为 int 类型,可以使用类似的方法:

sql 复制代码
CREATE VIEW my_view AS
SELECT 
    order_id,
    order_date,
    CAST(total_amount * 1.1 AS SIGNED) AS adjusted_total
FROM 
    orders;

在这个示例中,adjusted_total 是将 total_amount 乘以 1.1 后并转换为 int 类型的新字段。

你还可以使用 CONVERT() 函数来实现类似的目的:

sql 复制代码
CREATE VIEW my_view AS
SELECT 
    order_id,
    CONVERT(price, SIGNED) AS price_as_int
FROM 
    orders;

请注意,在视图中定义字段时需要仔细考虑数据类型转换的实际需求,以确保不会丢失数据的精度或重要信息。

复杂demo

sql 复制代码
create or replace view spider_status_insight as (select *, 
cast(substring(remark, 9, instr(remark, ",") - 9) as SIGNED) as updated,
cast(substring(remark, position("inserted" in remark) + 9) as SIGNED)  as inserted
 from spider_status);
相关推荐
文牧之25 分钟前
Oracle 审计参数:AUDIT_TRAIL 和 AUDIT_SYS_OPERATIONS
运维·数据库·oracle
篱笆院的狗27 分钟前
如何使用 Redis 快速实现布隆过滤器?
数据库·redis·缓存
洛神灬殇1 小时前
【LLM大模型技术专题】「入门到精通系列教程」基于ai-openai-spring-boot-starter集成开发实战指南
网络·数据库·微服务·云原生·架构
小鸡脚来咯2 小时前
redis分片集群架构
数据库·redis·架构
全都是浮夸丶2 小时前
MVCC理解
mysql
christine-rr2 小时前
征文投稿:如何写一份实用的技术文档?——以软件配置为例
运维·前端·网络·数据库·软件构建
HyggeBest2 小时前
Mysql 宏观架构
mysql·架构
海尔辛3 小时前
SQL 基础入门
数据库·sql
jiunian_cn3 小时前
【Linux】Linux权限
linux·服务器·mysql
betazhou4 小时前
有没有 MariaDB 5.5.56 对应 MySQL CONNECTION_CONTROL 插件
linux·数据库·mysql·oracle·mariadb