Skip to main content

Stored Function in SQL

Stored Function in SQL

  • Function is mainly used in the case where it must return a value.
  • Function can be called from SQL statements.
  • You can have DML (insert,update, delete) statements in a function.
  • Function returns 1 value only. 
Mysql:
Simple function to return cube

CREATE FUNCTION `calcube`(`PID` INT)
          RETURNS INT(11)
          RETURN PID * PID * PID

Function to return student division based on marks
DELIMITER $$

CREATE FUNCTION resultRemark(mark1 int,mark2 int,mark3 int,mark4 int,mark5 int)
RETURNS VARCHAR(50)
          DETERMINISTIC
BEGIN
         DECLARE lvl varchar(50);
DECLARE total int;
DECLARE percentage double;
SET total = mark1 + mark2 + mark3 + mark4 + mark5;
SET percentage = (total*100)/500;
         IF percentage >= 60 THEN
                SET lvl = '1st division';
         ELSEIF (percentage >= 50) THEN
                SET lvl = '2nd division';
         ELSEIF (percentage >= 40) THEN
               SET lvl = '3rd division';
ELSE
SET lvl = 'You are failed';
    END IF;

 RETURN (lvl);
END

MS SQL Server

Create function to change the date into different dateFormat equivalent to mysql date_format function

CREATE FUNCTION [dbo].[DATE_FORMAT](@Datetime DATETIME, @FormatMask VARCHAR(32))
RETURNS VARCHAR(32)
AS
BEGIN
    DECLARE @StringDate VARCHAR(32)
    SET @StringDate = @FormatMask
IF (CHARINDEX ('%Y' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
        SET @StringDate = REPLACE(@StringDate, '%Y' collate SQL_Latin1_General_CP1_CS_AS,
                         DATENAME(YYYY, @Datetime))
IF (CHARINDEX ('%y' Collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%y' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT(DATENAME(YYYY, @Datetime),2))
    IF (CHARINDEX ('%M' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%M' collate SQL_Latin1_General_CP1_CS_AS,
                         DATENAME(MM, @Datetime))
    IF (CHARINDEX ('%b' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%b' collate SQL_Latin1_General_CP1_CS_AS,
                                     LEFT(DATENAME(MM, @Datetime),3))
    IF (CHARINDEX ('%m' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%m' collate SQL_Latin1_General_CP1_CS_AS,
                  RIGHT('0'+CONVERT(VARCHAR,DATEPART(MM, @Datetime)),2))
    IF (CHARINDEX ('%d' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%d' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT('0'+DATENAME(DD, @Datetime),2))
IF (CHARINDEX ('%h' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%h' collate SQL_Latin1_General_CP1_CS_AS,
                         LEFT(RIGHT('0'+LTRIM(RIGHT(CONVERT(VARCHAR,                                    CONVERT(DATETIME,@Datetime), 100),7)),7),2))
    IF (CHARINDEX ('%H' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%H' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT('0'+DATENAME(HOUR, @Datetime),2))
IF (CHARINDEX ('%i' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%i' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT('0'+DATENAME(n, @Datetime),2))
IF (CHARINDEX ('%s' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%s' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT('0'+DATENAME(SECOND, @Datetime),2))
IF (CHARINDEX ('%S' collate SQL_Latin1_General_CP1_CS_AS,@StringDate) > 0)
       SET @StringDate = REPLACE(@StringDate, '%S' collate SQL_Latin1_General_CP1_CS_AS,
                         RIGHT('0'+DATENAME(SECOND, @Datetime),2))
   RETURN @StringDate
END

Use it using date_format(created,'%Y-%m-%d')

Comments

  1. SQL is a standard language for accessing databases. Its very helpful for the developer for finding data from many tables. And also perform insert, delete, update, etc operation on the tables.

    Thanks for sharing this query.......

    ReplyDelete

Post a Comment

Popular posts from this blog

Generate XML file in Cakephp

Steps to Generate XML file using CakePHP: Step-1 Enable to parse xml extension in config route.php file.     Router::parseExtensions('xml'); Step-2 Add Request Handler Component to the Controller    var $components = array(‘RequestHandler’); Step-3 Add controller Action For XML Generation in Post Controller     function generateXMLFile()     {         if ($this->RequestHandler->isXml()) { // check request type             $this->layout = 'empty'; // create an empty layout in app/views/layouts/empty.ctp              }        }  Add header code in empty layout <?php header('Content-type: text/xml');?> <?php echo $this->Xml->header(); ?> <?php echo $content_for_layout; ?> Step-4 Set up View To generate XML Create xml folder inside Posts vi...

How To Create Shortcodes In WordPress

We can create own shortcode by using its predified hooks add_shortcode( 'hello-world', 'techsudhir_hello_world_shortcode' ); 1. Write the Shortcode Function Write a function with a unique name, which will execute the code you’d like the shortcode to trigger: function techsudhir_hello_world_shortcode() {    return 'Hello world!'; } Example: [hello-world] If we were to use this function normally, it would return Hello world! as a string 2. Shortcode function with parameters function techsudhir_hello_world_shortcode( $atts ) {    $a = shortcode_atts( array(       'name' => 'world'    ), $atts );    return 'Hello ' . $a['name'] . !'; } Example: [hello-world name="Sudhir"] You can also call shortcode function in PHP using do_shortcode function Example: do_shortcode('[hello-world]');

How to replace plain URLs with links

Here we will explain how to replace Urls with links from string Using PHP $string ='Rajiv Uttamchandani is an astrophysicist, human rights activist, and entrepreneur. Academy, a nonprofit organization dedicated to providing a robust technology-centered education program for refugee and displaced youth around the world.  CNN Interview - https://www.youtube.com/watch?v=EtTwGke6Jtg   CNN Interview - https://www.youtube.com/watch?v=g7pRTAppsCc&feature=youtu.be'; $string = preg_replace('@(https?://([-\w\.]+)+(:\d+)?(/([\w/_\.%-=#]*(\?\S+)?)?)?)@', '<a href="$1">$1</a>', $string); Using Javascript <script> function linkify(inputText) {     var replacedText, replacePattern1, replacePattern2, replacePattern3;     //URLs starting with http://, https://, or ftp://     replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;     replacedText = inputT...