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);
相关推荐
bqq1986102617 分钟前
MySQL性能优化
mysql·mysql优化
雨辰AI1 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20242 小时前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有2 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao2 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839492 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录3 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约3 小时前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love4 小时前
MySQL的执行流程
android·数据库·mysql
海市公约4 小时前
一条SQL查询的完整旅程:MySQL执行流程深度解析
sql·mysql·数据库优化·执行计划·连接器·查询缓存·sql执行原理