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);
相关推荐
Smile丶凉轩1 小时前
Qt 界面优化(绘图)
开发语言·数据库·c++·qt
昔柯的修炼日记1 小时前
使用 Navicat 将 Excel 导入数据库
数据库
进击的雷神4 小时前
数据库知识全面考查:从基础概念到实战应用
jvm·数据库·oracle
Le_ee4 小时前
sqli-labs靶场第七关——文件导出注入
数据库·sql·网络安全·php·sql注入·sqli—labs
dddaidai1234 小时前
分布式ID和分布式锁
redis·分布式·mysql·zookeeper·etcd
不知几秋5 小时前
Maven
java·数据库·maven
政沅同学5 小时前
数据库实验报告 SQL SERVER 2008的基本操作 1
数据库
lyw2056195 小时前
MySQL八股(自用)
数据库·mysql
MMMMMMMMMMemory6 小时前
pgsql14自动创建表分区
数据库·pgsql
文牧之6 小时前
PostgreSQL 配置设置函数
运维·数据库·postgresql