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);
相关推荐
马克Markorg5 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_7 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy7 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道9 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707539 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha9 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_9 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance9 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋9 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.10 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库