Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/wix/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Database 是否可以更改视图中列的数据类型?_Database_Sql Server 2008_Tsql_View_Sqldatatypes - Fatal编程技术网

Database 是否可以更改视图中列的数据类型?

Database 是否可以更改视图中列的数据类型?,database,sql-server-2008,tsql,view,sqldatatypes,Database,Sql Server 2008,Tsql,View,Sqldatatypes,通常我运行这样的脚本: ALTER TABLE [TABLE] ALTER COLUMN [Column] NVARCHAR(40); 结果是表中的字段被转换为nvarchar。但是,对视图执行相同操作的语法是什么?或者这可能吗?当然 CREATE VIEW AView AS SELECT CAST(title AS char(50)) FROM titles 因此,请查看msdn页面上的CAST和CONVERT,以获取完整信息。是。。您可以尝试使用CONVERT函数来完成此操作 Conve

通常我运行这样的脚本:

ALTER TABLE [TABLE]
ALTER COLUMN [Column] NVARCHAR(40);
结果是表中的字段被转换为nvarchar。但是,对视图执行相同操作的语法是什么?或者这可能吗?

当然

CREATE VIEW AView
AS
SELECT CAST(title AS char(50))
FROM titles

因此,请查看msdn页面上的CAST和CONVERT,以获取完整信息。

是。。您可以尝试使用CONVERT函数来完成此操作

Convert (Desired datatype,column name)
例如,
Convert(varchar(50),dbo.User\u master.User\u email)
其中,用户_电子邮件以前的类型为nvarchar(MAX)

若要将nvarchar数据转换为datetime,则需要额外的参数来转换函数,如

CONVERT(data_type(length),expression,style)
例如,
Convert(Datetime,dbo.User\u master.User\u DOB,103)


更多信息位于

您不能指定视图输出列的数据类型。您最好按照@buckley的建议执行—使用CAST或CONVERT强制在视图定义中内联显式数据类型。