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);
相关推荐
qq_5298353512 分钟前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New3 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6753 小时前
数据库基础1
数据库
我爱松子鱼3 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo3 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser4 小时前
【SQL】多表查询案例
数据库·sql
Galeoto4 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)5 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231115 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql
喝醉酒的小白5 小时前
PostgreSQL:更新字段慢
数据库·postgresql