Search This Blog

Friday, November 22, 2013

ASCII SQL Server

SQL Server > Built-in Functions > ASCII

Returns the ASCII code value of the character






Example

SELECT ASCII('D'),ASCII('d')

Result:
68 100

Thursday, November 21, 2013

Built-In Functions SQL Server

SQL Server > Built-in Functions

String
Aggregate
Conversion
Rank
Date and Time
System
Mathematical
Metadata







      Generics C#

      C# > Generics

      Generics means the concept of type parameters. In this way it is possible to design classes  that defer the specification of types until the class is declared and instantiated.
      • generic types maximize code reuse, type safety, and performance.
      • T is generic type parameter
      Links                                                                                                  

      Example: Simple generic list                                                           

      public class GenericList<T>
      {
          private List<T> l = new List<T>();
          public void Add(T element)
          {
             l.Add(element);
          }
      }

      GenericList<int> lst1 = new GenericList<int>();
      lst1.Add(1);

      GenericList<string> lst2 = new GenericList<string>();
      lst2.Add("generics");








      HashSet C# Example

      C# > Generics > HashSet

      HashSet is an optimized set of value collection. A set is a collection that contains no duplicate elements.

      Note: The elements are not in a particular order

      Example:
       
      Use UnionWith to merge two sets with millions of elements
                  
                  HashSet<int> s1 = new HashSet<int>();
                  HashSet<int> s2 = new HashSet<int>();
                  for (int i = 0; i < 1000000; i++)
                  {
                      s1.Add(i);
                  }
                  for (int i = 1000001; i < 2000000; i++)
                  {
                      s2.Add(i);
                  }
                  HashSet<int> s3 = new HashSet<int>(s1);
                  s3.UnionWith(s2);
                  if (s3.Contains(1500000))
                  {
                      MessageBox.Show("1,500,000 element found in HashSet"); 
                  }




      Design Patterns C#

      C# > Design patterns

      A design pattern provides a framework for building an application. Design patterns makes the design process cleaner and more efficient. You can use existing design patterns to make templates for your objects and allowing you to build software faster.





      Singleton pattern C# Example

       C# > Design Patterns > Singleton

      Singleton is used to restrict instantiation of a class to one object. In this way we ensure that the class has only one instance.

      When to use?

      Usually singletons are used for centralized management  and provide a global point of access to themselves.
      • logging
      • configuration
      • resources

      Example

      using System;
      using System.Collections.Generic;
      using System.ComponentModel;
      using System.Data;
      using System.Drawing;
      using System.Linq;
      using System.Text;
      using System.Threading.Tasks;
      using System.Windows.Forms;

      namespace WindowsFormsApplication1
      {
          class Singleton
          {
              private static Singleton instance;
              protected Singleton()
              {
                // protected constructor
              }
       
                   public static Singleton GetInstance()
              {
                  if (instance == null)
                  {
                      lock (typeof(Singleton))
                      {
                          instance = new Singleton();
                      }
                  }
                  return instance;
              }
          }

          public partial class Form1 : Form
          {
              public Form1()
              {
                  InitializeComponent();
              }
              private void Form1_Load(object sender, EventArgs e)
              {
                  // Singleton st = new Singleton(); Error  'WindowsFormsApplication1.Singleton.Singleton()' is inaccessible due to its protection level
                  Singleton st1 = Singleton.GetInstance();
                  Singleton st2 = Singleton.GetInstance(); // st2=st1
              }
          }
      }

       





      Wednesday, November 20, 2013

      LINQ to DataSet - Filtering with DataView C#

      C# > System.Data   > DataSet > Linq to DataSet

      DataView can be created from a LINQ to DataSet query.

      Example:

      Create a DataView from a LINQ to DataSet query with a Where clause

      using System;
      using System.Collections.Generic;
      using System.ComponentModel;
      using System.Data;
      using System.Drawing;
      using System.IO;
      using System.Linq;
      using System.Runtime.InteropServices;
      using System.Text;
      using System.Threading.Tasks;
      using System.Windows.Forms;

      namespace WindowsFormsApplication1
      {
          public partial class Form1 : Form
          {
              public Form1()
              {
                  InitializeComponent();
              }
              private void Form1_Load(object sender, EventArgs e)
              {
                  DataSet ds = new DataSet();
                  ds.Tables.Add("Product");

                  DataTable dt = ds.Tables[0];
                  dt.Columns.Add("id", typeof(Int32));
                  dt.Columns.Add("name", typeof(string));
                  dt.Columns.Add("quantity", typeof(Int32));

                  fillDataTable(dt);

                  EnumerableRowCollection<DataRow> query = from p in ds.Tables[0].AsEnumerable()
                                                           where p.Field<Int32>("quantity") > 50 && p.Field<Int32>("quantity") < 70
                                                           select p;
                  DataView view = query.AsDataView();
                  BindingSource bs = new BindingSource();
                  bs.DataSource = view;
              }

              void fillDataTable(DataTable dt)
              {
                  for (int i = 0; i < 100; i++)
                  {
                      DataRow dr = dt.NewRow();
                      dr[0] = i;
                      dr[1] = "Product ";
                      dr[2] = i;
                      dt.Rows.Add(dr);
                  }
              }
          }
      }