Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Need help converting simple function in SQL Server from Oracle...

Posted on 2009-05-14
5
Medium Priority
?
259 Views
Last Modified: 2012-05-07
I am an Oracle PL/SQL guy but have hit an issue in trying to get this function converted to SQL Server.

The TO_CHAR piece of this doesn't exist (among other things).

Can someone please help me convert this?

Thanks in advance!

B
CREATE OR REPLACE FUNCTION format_sequence (p_number IN INTEGER)
    RETURN VARCHAR2
IS
    v_num   INTEGER := FLOOR (p_number / 1000);
BEGIN
    RETURN    CHR (FLOOR (v_num / (26 * 26)) + 65)
           || CHR (FLOOR (MOD (v_num, 26 * 26) / 26) + 65)
           || CHR (MOD (v_num, 26) + 65)
           || TO_CHAR (MOD (p_number, 1000), 'fm000');
END;

Open in new window

0
Comment
Question by:cyimxtck
  • 3
  • 2
5 Comments
 
LVL 43

Accepted Solution

by:
pcelba earned 2000 total points
ID: 24388236
The function is here:
USE [Expres]
GO
/****** Object:  UserDefinedFunction [dbo].[format_sequence]    Script Date: 05/14/2009 20:53:12 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:		<Author,,Name>
-- Create date: <Create Date, ,>
-- Description:	<Description, ,>
-- =============================================
CREATE FUNCTION [dbo].[format_sequence] 
(
	-- Add the parameters for the function here
	@p_number int
)
RETURNS varchar(6)
AS
BEGIN
	-- Declare the return variable here
	DECLARE @ResultVar varchar(6)
	DECLARE @v_num int
	
	SET @v_num = FLOOR (@p_number / 1000)
 
    SET @ResultVar = CHAR (FLOOR (@v_num / (26 * 26)) + 65)
           + CHAR (FLOOR ((@v_num % (26 * 26)) / 26) + 65)
           + CHAR (@v_num % 26 + 65)
           + REPLACE(STR (@p_number % 1000, 3, 0),' ','0')
 
	-- Return the result of the function
	RETURN @ResultVar
 
END

Open in new window

0
 

Author Comment

by:cyimxtck
ID: 24388389
PERFECT and exactly what I needed.

Thank you so much!!!!
0
 

Author Closing Comment

by:cyimxtck
ID: 31581597
Perfect in every way!
0
 
LVL 43

Expert Comment

by:pcelba
ID: 24388419
The
USE [Expres]
GO
at the beginning should be replaced by your database name.

If you'll modify this function, you have to change
CREATE FUNCTION
to
ALTER FUNCTION
0
 

Author Comment

by:cyimxtck
ID: 24388431
I have already done that (so different than Oracle) but thank you so much!

B
0

Featured Post

Important Lessons on Recovering from Petya

In their most recent webinar, Skyport Systems explores ways to isolate and protect critical databases to keep the core of your company safe from harm.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Hi all, It is important and often overlooked to understand “Database properties”. Often we see questions about "log files" or "where is the database" and one of the easiest ways to get general information about your database is to use “Database p…
SQL Server engine let you use a Windows account or a SQL Server account to connect to a SQL Server instance. This can be configured immediatly during the SQL Server installation or after in the Server Authentication section in the Server properties …
This Micro Tutorial will teach you how to add a cinematic look to any film or video out there. There are very few simple steps that you will follow to do so. This will be demonstrated using Adobe Premiere Pro CS6.
This lesson discusses how to use a Mainform + Subforms in Microsoft Access to find and enter data for payments on orders. The sample data comes from a custom shop that builds and sells movable storage structures that are delivered to your property. …

879 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question