sql - 是否可以更改Sql Server中的数据类型Date

标签 sql sql-server sql-server-2008 sql-server-2008-r2

我住在伊朗,我们伊朗使用阳历日期而不是公历日期。是否可以将 Date 数据类型从公历日期更改为太阳日期。另外,我想在查询中使用日期函数,例如 DateAdd() 、 DateDiff() 等。

编辑:

太阳日期的月份描述:

1-  31 day
2-  31 day
3-  31 day
4-  31 day
5-  31 day
6-  31 day
7-  30 day
8-  30 day
9-  30 day
10- 30 day
11- 30 day
12- 29 day (in Leap year 30 day)
SUM-365 day in each year

太阳日期的开始时间为每个公历日期的 23-3-...。

编辑 1

我在 SQL Server 中使用以下函数将公历日期转换为太阳日期:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[PersianDate]
(@MiladiDate DATE)
returns varchar(10)
AS
BEGIN
    Declare @days int
    Declare @year int
    set @year=Year(@MiladiDate) 
    Declare @month int  
    Set @days=DATEDIFF ( day ,  Convert(Date,cast(Year(@MiladiDate) as varchar)+'/1/1'), @MiladiDate)+1
    if @days>79  --یعنی یک فروردین ماه
    begin
        set @days=@days-79
        if @days<=186
        begin
            set @month=@days/31;
            if (@days%31=0)
                set @days=31
            else
            begin
                set @month=@month+1
                set @days=@days%31
            end
        end
        else
        begin
            set @days=@days-186
            set @month=6+@days/30;
            if (@days%30=0)
                set @days=30
            else
            begin
                set @month=@month+1
                set @days=@days%30
            end
        end
        set @year=@Year-621
    end
    else
    begin
        set @year=@year-1   
        if (((@Year % 100)<> 0 and (@Year % 4) = 0) or ((@Year % 100)= 0 and (@Year % 400) = 0))
            set @days=@days+11
        else
            set @days=@days+10
        set @month=@days/30+9
        if (@days%30=0)
            set @days=30
        else
        begin
            set @month=@month+1
            set @days=@days%30
        end
        set @year=@year-621
    end
    RETURN cast (@year as varchar)+'/'+ 
                                    case
                                    when @month<10 then '0'
                                    else ''
                                    END
                                    + cast (@month as varchar)+'/'+
                                    case 
                                    when @days<10 then '0'
                                    else ''
                                    END
                                    + cast (@days as varchar)
END

编辑2

要将阳历日期转换为公历日期可以使用 CLR 函数:

Create CLR Function

最佳答案

我建议您构建一个日历表,其中包含公历日期和太阳日期作为两列(以及其他列,例如星期几、月份编号、年份、月份名称) 。您应该能够在 Excel 中轻松构建这样的表格,然后将其导入到表格中。

然后,您可以采取两种方法之一。第一种是将所有日期存储为公历日期,然后查找日期值以在输入和输出时进行转换。如果您想使用许多内置的日期功能,您可以这样做。

第二种方法是将日期存储为表示太阳日期的字符串。然后,当您想要进行内置运算时,可以使用该表格转换为公历日期。但是,您可能会发现仅拥有一个日历表就无需使用大多数内置功能。<​​/p>

关于sql - 是否可以更改Sql Server中的数据类型Date,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10948351/

相关文章:

sql - 在postgres中使用GROUP BY子句时如何聚合json字段?

MySQL 连接返回的行数多于预期的行数

SQL : join 3 tables and show all data from the 2 tables in sub query

sql-server-2008 - 从 XML 列中获取值

sql - 为什么比较在 CONVERT 中不起作用?

php - 管理每周时间表的数据库模式

sql - 启用/禁用/删除数据库行及其引用的最佳实践?

mysql - SQL Server Reporting Services 未从 SQL 存储过程传递正确的参数

SQL查询-如何按列值获取每个组的列的最大值

sql-server-2008 - Intellisense 未在 Sql Server 中更新