Say, as in Roman Calendar | Database Journal

Say, as in Roman Calendar

Jul 21, 2004
1 minute read

>>Script Language and Platform: SQL Server
This script will display the day of the month as in Roman Julian calendar

Usage:

select dbo.udf_RomanDay (’02/28/2004′)
–results
pridie Kal.Mar.
select dbo.udf_RomanDay (’12/01/2004′)
–results
Kalendae Decembres
select dbo.udf_RomanDay (’11/13/2004′)
–results
Idus Novembres

Author: MAK


Create function dbo.udf_RomanDay (@date datetime)
returns varchar(100)
as
begin
–Objective: To display day of the month as in Roman Calendar
–Created by: MAK
–Date : July 16, 2004
declare @monthval int
set @monthval =month(@date)
declare @dayval int
set @dayval=day(@date)
declare @romanday varchar(100)
if @monthval =1
begin
select @romanday = case @dayval
When 1 thenKalendae Januariae’
When 2 thena.d.IV.Non.Jan’
When 3 thena.d.III.Non.Jan.’
When 4 thenpridie Non.Jan.’
When 5 thenNonae Januariae’
When 6 thena.d.VIII.Id.Jan.’
When 7 thena.d.VII. Id.Jan.’
When 8 thena.d.VI. Id.Jan.’
When 9 thena.d.V. Id.Jan.’
When 10  thena.d.IV. Id.Jan.’
When 11 thena.d.III. Id.Jan.’
When 12 thenpridie Id.Jan.’
When 13 thenIdus Januariae’
When 14 thena.d.XIX.Kal.Feb.’
When 15 thena.d.XVIII.Kal.Feb.’
When 16 thena.d.XVII.Kal.Feb.’
When 17 thena.d.XVI.Kal.Feb.’
When 18 thena.d.XV.Kal.Feb.’
When 19 thena.d.XIV.Kal.Feb.’
When 20 then. a.d.XIII.Kal.Feb.’
When 21 thena.d.XII.Kal.Feb.’
When 22 thena.d.XI.Kal.Feb.’
When 23 thena.d.X.Kal.Feb.’
When 24 thena.d.IX.Kal.Feb.’
When 25 thena.d.VIII.Kal.Feb.’
When 26 thena.d.VII.Kal.Feb.’
When 27 thena.d.VI.Kal.Feb.’
When 28 thena.d.V.Kal.Feb.’
When 29 thena.d.IV.Kal.Feb.’
When 30 thena.d.III.Kal.Feb.’
When 31 thenpridie Kal.Feb.’
end
end
if @monthval =2
begin
select @romanday = case @dayval
When 1 thenKalendae Februariae’
When 2 thena.d.IV.Non.Feb.’
When 3 thena.d.III.Non.Feb.’
When 4 thenpridie Non. Feb.’
When 5 thenNonae Februariae’
When 6 thena.d.VIII.Id.Feb.’
When 7 thena.d.VII.Id.Feb.’
When 8 thena.d.VI.Id.Feb’
When 9 thena.d.V.Id.Feb.’
When 10  thena.d.IV.Id.Feb.’
When 11 thena.d.III.Id.Feb.’
When 12 thenpridie Id. Feb.’
When 13 thenIdus Februariae’
When 14 thena.d.XVI.Kal.Mar.’
When 15 thena.d.XV.Kal.Mar.’
When 16 thena.d.XIV.Kal.Mar.’
When 17 thena.d.XIII.Kal.Mar.’
When 18 thena.d.XII.Kal.Mar.’
When 19 thena.d.XI.Kal.Mar.’
When 20 thena.d.X.Kal.Mar.’
When 21 thena.d.IX.Kal.Mar.’
When 22 thena.d.VIII.Kal.Mar.’
When 23 thena.d.VII.Kal.Mar.’
When 24 thena.d.VI.Kal.Mar.’
When 25 thena.d.V.Kal.Mar.’
When 26 thena.d.IV.Kal.Mar.’
When 27 thena.d.III.Kal.Mar.’
When 28 thenpridie Kal.Mar.’
When 28 then NULL
end
end
if @monthval =3
begin
select @romanday = case @dayval
When 1 thenKalendae Martiae’
When 2 thena.d.VI.Non.Mar.’
When 3 thena.d.V.Non.Mar.’
When 4 thena.d.IV.Non.Mar.’
When 5 thena.d.III.Non.Mar.’
When 6 thenpridie Non.Mar.’
When 7 thenNonae Martiae’
When 8 thena.d.VIII.Id.Mar.’
When 9 thena.d.VII.Id.Mar.’
When 10  thena.d.VI.Id.Mar.’
When 11 thena.d.V.Id.Mar.’
When 12 thena.d.IV.Id.Mar.’
When 13 thena.d.III.Id.Mar.’
When 14 thenpridie Id.Mar.’
When 15 thenIdus Martiae’
When 16 thena.d.XVII.Kal.Apr.’
When 17 thena.d.XVI.Kal.Apr.’
When 18 thena.d.XV.Kal.Apr.’
When 19 thena.d.XIV.Kal.Apr.’
When 20 thena.d.XIII.Kal.Apr.’
When 21 thena.d.XII.Kal.Apr.’
When 22 thena.d.XI.Kal.Apr.’
When 23 thena.d.X.Kal.Apr.’
When 24 thena.d.IX.Kal.Apr.’
When 25 thena.d.VIII.Kal.Apr.’
When 26 thena.d.VII.Kal.Apr.’
When 27 thena.d.VI.Kal.Apr.’
When 28 thena.d.V.Kal.Apr.’
When 29 thena.d.IV.Kal.Apr.’
When 30 thena.d.III.Kal.Apr.’
When 31 thenpridie Kal.Apr.’
end
end
if @monthval =4
begin
select @romanday = case @dayval
When 1 thenKalendae Apriles’
When 2 thena.d.IV.Non.Apr.’
When 3 thena.d.III.Non.Apr.’
When 4 thenpridie Non.Apr.’
When 5 thenNonae Apriles’
When 6 thena.d.VIII.Id.Apr.’
When 7 thena.d.VII.Id.Apr.’
When 8 thena.d.VI.Id.Apr.’
When 9 thena.d.V.Id.Apr.’
When 10  thena.d.IV.Id.Apr.’
When 11 thena.d.III.Id.Apr.’
When 12 thenpridie Id.Apr.’
When 13 thenIdus Apriles’
When 14 thena.d.XVIII.Kal.Mai.’
When 15 thena.d.XVII.Kal.Mai.’
When 16 thena.d.XVI.Kal.Mai.’
When 17 thena.d.XV.Kal.Mai.’
When 18 thena.d.XIV.Kal.Mai.’
When 19 thena.d.XIII.Kal.Mai.’
When 20 thena.d.XII.Kal.Mai.’
When 21 thena.d.XI.Kal.Mai.’
When 22 thena.d.X.Kal.Mai.’
When 23 thena.d.IX.Kal.Mai.’
When 24 thena.d.VIII.Kal.Mai.’
When 25 thena.d.VII.Kal.Mai.’
When 26 thena.d.VI.Kal.Mai.’
When 27 thena.d.V.Kal.Mai.’
When 28 thena.d.IV.Kal.Mai.’
When 29 thena.d.III.Kal.Mai.’
When 30 thenpridie Kal.Mai.’
end
end
if @monthval =5
begin
select @romanday = case @dayval
When 1 thenKalendae Maiae’
When 2 thena.d.VI.Non.Mai.’
When 3 thena.d.V.Non.Mai.’
When 4 thena.d.IV.Non.Mai.’
When 5 thena.d.III.Non.Mai.’
When 6 thenpridie Non.Mai.’
When 7 thenNonae Maiae’
When 8 thena.d.VIII.Id.Mai.’
When 9 thena.d.VII.Id.Mai.’
When 10  thena.d.VI.Id.Mai.’
When 11 thena.d.V.Id.Mai.’
When 12 thena.d.IV.Id.Mai.’
When 13 thena.d.III.Id.Mai.’
When 14 thenpridie Id.Mai.’
When 15 thenIdus Maiae’
When 16 thena.d.XVII.Kal.Jun.’
When 17 thena.d.XVI.Kal.Jun.’
When 18 thena.d.XV.Kal.Jun.’
When 19 thena.d.XIV.Kal.Jun.’
When 20 thena.d.XIII.Kal.Jun.’
When 21 thena.d.XII.Kal.Jun.’
When 22 thena.d.XI.Kal.Jun.’
When 23 thena.d.X.Kal.Jun.’
When 24 thena.d.IX.Kal.Jun.’
When 25 thena.d.VIII.Kal.Jun.’
When 26 thena.d.VII.Kal.Jun.’
When 27 thena.d.VI.Kal.Jun.’
When 28 thena.d.V.Kal.Jun.’
When 29 thena.d.IV.Kal.Jun.’
When 30 thena.d.III.Kal.Jun.’
When 31 thenpridie Kal.Jun.’
end
end
if @monthval =6
begin
select @romanday = case @dayval
When 1 thenKalendae Juniae’
When 2 thena.d.IV.Non.Jun.’
When 3 thena.d.III.Non.Jun.t’
When 4 thenpridie Non.Jun.’
When 5 thenNonae Juniae’
When 6 thena.d.VIII.Id.Jun.’
When 7 thena.d.VII.Id.Jun.’
When 8 thena.d.VI.Id.Jun.’
When 9 thena.d.V.Id.Jun.’
When 10  thena.d.IV.Id.Jun.’
When 11 thena.d.III.Id.Jun.’
When 12 thenpridie Id.Jun.’
When 13 thenIdus Juniae’
When 14 thena.d.XVIII.Kal.Jul.’
When 15 thena.d.XVII.Kal.Jul.’
When 16 thena.d.XVI.Kal.Jul.’
When 17 thena.d.XV.Kal.Jul.’
When 18 thena.d.XIV.Kal.Jul.’
When 19 thena.d.XIII.Kal.Jul.’
When 20 thena.d.XII.Kal.Jul.’
When 21 thena.d.XI.Kal.Jul.’
When 22 thena.d.X.Kal.Jul.’
When 23 thena.d.IX.Kal.Jul.’
When 24 thena.d.VIII.Kal.Jul.’
When 25 thena.d.VII.Kal.Jul.’
When 26 thena.d.VI.Kal.Jul.’
When 27 thena.d.V.Kal.Jul.’
When 28 thena.d.IV.Kal.Jul.’
When 29 thena.d.III.Kal.Jul.’
When 30 thenpridie Kal.Jul.’
end
end
if @monthval =7
begin
select @romanday = case @dayval
When 1 thenKalendae Juliae’
When 2 thena.d.VI.Non.Jul.’
When 3 thena.d.V.Non.Jul.’
When 4 thena.d.IV.Non.Jul.’
When 5 thena.d.III.Non.Jul.’
When 6 thenpridie Non.Jul.’
When 7 thenNonae Juliae’
When 8 thena.d.VIII.Id.Jul.’
When 9 thena.d.VII.Id.Jul.’
When 10  thena.d.VI.Id.Jul.’
When 11 thena.d.V.Id.Jul.’
When 12 thena.d.IV.Id.Jul.’
When 13 thena.d.III.Id.Jul.’
When 14 thenpridie Id.Jul.’
When 15 thenIdus Juliae’
When 16 thena.d.XVII.Kal.Aug.’
When 17 thena.d.XVI.Kal.Aug.’
When 18 thena.d.XV.Kal.Aug.’
When 19 thena.d.XIV.Kal.Aug.’
When 20 thena.d.XIII.Kal.Aug.’
When 21 thena.d.XII.Kal.Aug.’
When 22 thena.d.XI.Kal.Aug.’
When 23 thena.d.X.Kal.Aug.’
When 24 thena.d.IX.Kal.Aug.’
When 25 thena.d.VIII.Kal.Aug.’
When 26 thena.d.VII.Kal.Aug.’
When 27 thena.d.VI.Kal.Aug.’
When 28 thena.d.V.Kal.Aug.’
When 29 thena.d.IV.Kal.Aug.’
When 30 thena.d.III.Kal.Aug.’
When 31 thenpridie Kal.Aug.’
end
end
if @monthval =8
begin
select @romanday = case @dayval
When 1 thenKalendae Augustae’
When 2 thena.d.IV.Non.Aug.’
When 3 thena.d.III.Non.Aug.’
When 4 thenpridie Non.Aug.’
When 5 thenNonae Augustae’
When 6 thena.d.VIII.Id.Aug.’
When 7 thena.d.VII.Id.Aug.’
When 8 thena.d.VI.Id.Aug.’
When 9 thena.d.V.Id.Aug.’
When 10  thena.d.IV.Id.Aug.’
When 11 thena.d.III.Id.Aug.’
When 12 thenpridie Id.Aug.’
When 13 thenIdus Augustae’
When 14 thena.d.XIX.Kal.Sept.’
When 15 thena.d.XVIII.Kal.Sept.’
When 16 thena.d.XVII.Kal.Sept.’
When 17 thena.d.XVI.Kal.Sept.’
When 18 thena.d.XV.Kal.Sept.’
When 19 thena.d.XIV.Kal.Sept.’
When 20 thena.d.XIII.Kal.Sept.’
When 21 thena.d.XII.Kal.Sept.’
When 22 thena.d.XI.Kal.Sept.’
When 23 thena.d.X.Kal.Sept.’
When 24 thena.d.IX.Kal.Sept.’
When 25 thena.d.VIII.Kal.Sept.’
When 26 thena.d.VII.Kal.Sept.’
When 27 thena.d.VI.Kal.Sept.’
When 28 thena.d.V.Kal.Sept.’
When 29 thena.d.IV.Kal.Sept.’
When 30 thena.d.III.Kal.Sept.’
When 31 thenpridie Kal.Sept.’
end
end
if @monthval =9
begin
select @romanday = case @dayval
When 1 thenKalendae Septembres’
When 2 thena.d.IV.Non.Sept.’
When 3 thena.d.III.Non.Sept.’
When 4 thenpridie Non.Sept.’
When 5 thenNonae Septembres’
When 6 thena.d.VIII.Id.Sept.’
When 7 thena.d.VII.Id.Sept.’
When 8 thena.d.VI.Id.Sept.’
When 9 thena.d.V.Id.Sept.’
When 10  thena.d.IV.Id.Sept.’
When 11 thena.d.III.Id.Sept.’
When 12 thenpridie Id.Sept.’
When 13 thenIdus Septembres’
When 14 thena.d.XVIII.Kal.Oct.’
When 15 thena.d.XVII.Kal.Oct.’
When 16 thena.d.XVI.Kal.Oct.’
When 17 thena.d.XV.Kal.Oct.’
When 18 thena.d.XIV.Kal.Oct.’
When 19 thena.d.XIII.Kal.Oct.’
When 20 thena.d.XII.Kal.Oct.’
When 21 thena.d.XI.Kal.Oct’
When 22 thena.d.X.Kal.Oct.’
When 23 thena.d.IX.Kal.Oct.’
When 24 thena.d.VIII.Kal.Oct.’
When 25 thena.d.VII.Kal.Oct.’
When 26 thena.d.VI.Kal.Oct.’
When 27 thena.d.V.Kal.Oct.’
When 28 thena.d.IV.Kal.Oct.’
When 29 thena.d.III.Kal.Oct.’
When 30 thenpridie Kal.Oct.’
end
end
if @monthval =10
begin
select @romanday = case @dayval
When 1 thenKalendae Octobres’
When 2 thena.d.VI.Non.Oct.’
When 3 thena.d.V.Non.Oct.’
When 4 thena.d.IV.Non.Oct.’
When 5 thena.d.III.Non.Oct.’
When 6 thenpridie Non.Oct.’
When 7 thenNonae Octobres’
When 8 thena.d.VIII.Id.Oct.’
When 9 thena.d.VII.Id.Oct.’
When 10  thena.d.VI.Id.Oct.’
When 11 thena.d.V.Id.Oct.’
When 12 thena.d.IV.Id.Oct.’
When 13 thena.d.III.Id.Oct.’
When 14 thenpridie Id.Oct.’
When 15 thenIdus Octobres’
When 16 thena.d.XVII.Kal.Nov.’
When 17 thena.d.XVI.Kal.Nov.’
When 18 thena.d.XV.Kal.Nov.’
When 19 thena.d.XIV.Kal.Nov.’
When 20 thena.d.XIII.Kal.Nov.’
When 21 thena.d.XII.Kal.Nov.’
When 22 thena.d.XI.Kal.Nov.’
When 23 thena.d.X.Kal.Nov.’
When 24 thena.d.IX.Kal.Nov.’
When 25 thena.d.VIII.Kal.Nov.’
When 26 thena.d.VII.Kal.Nov.’
When 27 thena.d.VI.Kal.Nov.’
When 28 thena.d.V.Kal.Nov.’
When 29 thena.d.IV.Kal.Nov.’
When 30 thena.d.III.Kal.Nov.’
When 31 thenpridie Kal.Nov.’
end
end
if @monthval =11
begin
select @romanday = case @dayval
When 1 thenKalendae Novembres’
When 2 thena.d.IV.Non.Nov.’
When 3 thena.d.III.Non.Nov.’
When 4 thenpridie Non.Nov.’
When 5 thenNonae Novembres’
When 6 thena.d.VIII.Id.Nov.’
When 7 thena.d.VII.Id.Nov.’
When 8 thena.d.VI.Id.Nov.’
When 9 thena.d.V.Id.Nov.’
When 10  thena.d.IV.Id.Nov.’
When 11 thena.d.III.Id.Nov.’
When 12 thenpridie Id.Nov.’
When 13 thenIdus Novembres’
When 14 thena.d.XVIII.Kal.Dec.’
When 15 thena.d.XVII.Kal.Dec.’
When 16 thena.d.XVI.Kal.Dec.’
When 17 thena.d.XV.Kal.Dec.’
When 18 thena.d.XIV.Kal.Dec.’
When 19 thena.d.XIII.Kal.Dec.’
When 20 thena.d.XII.Kal.Dec.’
When 21 thena.d.XI.Kal.Dec.’
When 22 thena.d.X.Kal.Dec.’
When 23 thena.d.IX.Kal.Dec.’
When 24 thena.d.VIII.Kal.Dec.’
When 25 thena.d.VII.Kal.Dec.’
When 26 thena.d.VI.Kal.Dec.’
When 27 thena.d.V.Kal.Dec.’
When 28 thena.d.IV.Kal.Dec.’
When 29 thena.d.III.Kal.Dec.’
When 30 thenpridie Kal.Dec.’
end
end
if @monthval =12
begin
select @romanday = case @dayval
When 1 thenKalendae Decembres’
When 2 thena.d.IV.Non.Dec.’
When 3 thena.d.III.Non.Dec.’
When 4 thenpridie Non.Dec.’
When 5 thenNonae Decembres’
When 6 thena.d.VIII.Id.Dec.’
When 7 thena.d.VII.Id.Dec.’
When 8 thena.d.VI.Id.Dec.’
When 9 thena.d.V.Id.Dec.’
When 10  thena.d.IV.Id.Dec.’
When 11 thena.d.III.Id.Dec.’
When 12 thenpridie Id.Dec.’
When 13 thenIdus Decembres’
When 14 thena.d.XIX.Kal.Jan.’
When 15 thena.d.XVIII.Kal.Jan.’
When 16 thena.d.XVII.Kal.Jan.’
When 17 thena.d.XVI.Kal.Jan’
When 18 thena.d.XV.Kal.Jan.’
When 19 thena.d.XIV.Kal.Jan.’
When 20 thena.d.XIII.Kal.Jan.’
When 21 thena.d.XII.Kal.Jan.’
When 22 thena.d.XI.Kal.Jan.’
When 23 thena.d.X.Kal.Jan.’
When 24 thena.d.IX.Kal.Jan.’
When 25 thena.d.VIII.Kal.Jan.’
When 26 thena.d.VII.Kal.Jan.’
When 27 thena.d.VI.Kal.Jan.’
When 28 thena.d.V.Kal.Jan.’
When 29 thena.d.IV.Kal.Jan.’
When 30  thena.d.III.Kal.Jan.’
When 31 thenpridie Kal.Jan.’
end
end
return @romanday
end



Disclaimer:
We hope that the information on these script pages is
valuable to you. Your use of the information contained in these pages,
however, is at your sole risk. All information on these pages is provided
“as -is”, without any warranty, whether express or implied, of its accuracy,
completeness, or fitness for a particular purpose…

Disclaimer Continued

Back to Database Journal Home

Database Journal Logo

DatabaseJournal.com publishes relevant, up-to-date and pragmatic articles on the use of database hardware and management tools and serves as a forum for professional knowledge about proprietary, open source and cloud-based databases--foundational technology for all IT systems. We publish insightful articles about new products, best practices and trends; readers help each other out on various database questions and problems. Database management systems (DBMS) and database security processes are also key areas of focus at DatabaseJournal.com.

Property of TechnologyAdvice. © 2026 TechnologyAdvice. All Rights Reserved

Advertiser Disclosure: Some of the products that appear on this site are from companies from which TechnologyAdvice receives compensation. This compensation may impact how and where products appear on this site including, for example, the order in which they appear. TechnologyAdvice does not include all companies or all types of products available in the marketplace.