# Tuesday, August 10, 2010
Tip of the Day: Creating a control that displays multiple types of messages using the IValidator interface
Tuesday, August 10, 2010 6:06:51 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Monday, August 09, 2010
My first journey through expression trees and dynamic lambda expressions, and an explanation on how I got there. The end result is a case-insensitive search and a wildcard search function.
Monday, August 09, 2010 5:34:12 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, August 05, 2010
Tip of the Day: Extension method to HTML encode a string
Thursday, August 05, 2010 2:39:30 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, August 04, 2010
Tip of the Day: T-SQL Script to rename bulk columns
Wednesday, August 04, 2010 5:22:15 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, August 03, 2010
Retrieve the column name which have uniqie constraints on them in a CodeSmith template.
Tuesday, August 03, 2010 6:13:07 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, March 11, 2010
Explore the INFORMATION_SCHEMA to get more useful metadata information on your database, much simpler than using sysobjects!
Thursday, March 11, 2010 4:02:00 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, March 10, 2010
Retaining employees after this economy changes needs to start now!
Wednesday, March 10, 2010 3:18:49 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, March 05, 2010
Script to ferret out those procs you forgot to create permissions for!
Friday, March 05, 2010 4:36:29 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, March 02, 2010
Tip of the Day: Manipulating ASP.Net validators client side
Tuesday, March 02, 2010 4:29:40 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, January 06, 2010
How to register class based user controls in a web project
Wednesday, January 06, 2010 3:52:06 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, December 30, 2009
Extension method for providing dynamic sorting based on field names of a List collection.
Wednesday, December 30, 2009 4:58:02 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, December 29, 2009
Two useful menu items to help eliminate "using" clutter in VS2008.
Tuesday, December 29, 2009 4:43:28 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, November 11, 2009
Adding carriage returns to SSIS package annotations
Wednesday, November 11, 2009 5:13:49 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Saturday, November 07, 2009
More promising features of VS2010
Saturday, November 07, 2009 3:45:19 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, November 06, 2009
Tip of the day: marking routines obsolete, and enforcing it!
Friday, November 06, 2009 3:43:11 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Saturday, October 31, 2009
Some of the great features of Visual Studio 2010 which are very appealing to me!
Saturday, October 31, 2009 4:22:38 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, October 30, 2009
Using generics to simplify getting data from a SqlDataRow or DataRow object.
Friday, October 30, 2009 4:17:54 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, October 29, 2009
Launch another program, and optionally wait for it to complete.
Thursday, October 29, 2009 4:12:31 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, October 28, 2009
A simple validation routine to validate a string meets the minimum and maximum length requirements.
Wednesday, October 28, 2009 4:09:54 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, October 14, 2009
WinForm: The base class % could not be loaded.
Wednesday, October 14, 2009 6:27:16 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, September 29, 2009
Using the MasterType directive to programatically access you Master Page.
Tuesday, September 29, 2009 5:34:35 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, September 25, 2009
Placing page trace information in a file instead of on the page
Friday, September 25, 2009 6:11:05 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, September 23, 2009
Interview question -- the virtual keyword
Wednesday, September 23, 2009 5:45:06 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
Fancy tooltips in WinForms!
Wednesday, September 23, 2009 4:58:23 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, September 22, 2009
Adding a WinForm tooltip without the control..
Tuesday, September 22, 2009 5:38:13 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, September 16, 2009
How to enumerate all the shortcut keys in the Visual Studio IDE
Wednesday, September 16, 2009 6:22:12 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Monday, September 07, 2009
Debugging trick for placing a condition on a breakpoint to assist in speeding up debugging.
Monday, September 07, 2009 11:46:14 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
How to make the Visual Studio debugger break where the error actually occurs.
Monday, September 07, 2009 11:28:20 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, September 04, 2009
Tipf of the Day: A brief discussion of the new Extension Methods in .Net 3.5
Friday, September 04, 2009 6:10:29 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, September 03, 2009
Starting a new project, how to approach it?
Thursday, September 03, 2009 8:41:58 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, September 02, 2009

I can't take credit for this, as I took it from the article How To Get Table Row Counts Quickly And Painlessly on SqlServerCentral.com by Kendal Van Dyke. However, it such a good tip, I had to change it a bit, as I tend to use this a LOT.

First, I made the results a little more "printable" but reducing the table name column. Next, I made it a system proc because when I go onto client sites, I am looking at many databases. I probably don't need to create a procedure for it, but there have been many cases where I trend things, and it would be nice to have this handy. Finally, I added a parameter to allow me to change the sorting. By default, it sorts by table name. I added an optional parameter to allow me to pass in an integer (could have done it a million ways, I know, but I chose to do this solely for my preferences -- feel free to change to yours).

Usagesp_retrieveRowCounts    --- sorts by table name

            sp_retrieveRowCounts 1  ---sorts by row count, then table name

Here's the proc:


USE master
GO

IF (SELECT OBJECT_ID('sp_retrieveRowCounts','P')) IS NOT NULL
BEGIN
    DROP PROC sp_retrieveRowCounts
END
GO


CREATE PROC sp_retrieveRowCounts (@OrderByCount int = null)
AS
BEGIN

    DECLARE @OrderByParm int
    DECLARE @SQLStatement varchar(700)
    DECLARE @OrderByClause varchar(35)
    
    SELECT @OrderByParm = ISNULL(@OrderByCount,0)

    IF (@OrderByParm != 0)
        SELECT @OrderByClause = ' ddps.row_count DESC, o.NAME ASC'
    ELSE
        SELECT @OrderByClause = ' o.NAME ASC'

    SELECT @SQLStatement = 'SELECT TableName = LEFT(o.name,50), TotalRows = ddps.row_count FROM sys.indexes AS i
     INNER JOIN sys.objects AS o ON i.OBJECT_ID = o.OBJECT_ID
     INNER JOIN sys.dm_db_partition_stats AS ddps ON i.OBJECT_ID = ddps.OBJECT_ID
     AND i.index_id = ddps.index_id
    WHERE i.index_id < 2
     AND o.is_ms_shipped = 0
    ORDER BY '
+ @OrderByClause
    
    EXEC(@SQLStatement)

END

--Mark procedure as system object
EXEC sys.sp_MS_marksystemobject sp_retrieveRowCounts
GO


GRANT EXEC ON sp_retrieveRowCounts TO public
GO

 

Wednesday, September 02, 2009 6:34:10 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, September 01, 2009

When I go onto a client site, I usually don't have the luxury of designing everything from scratch. There are times (like on my current engagement) if I were given the choice, I'd say scrap it, but usually it doesn't happen that way. It is what it is... been saying that a lot lately!

So one of the tools I find useful is the ability to search for particular field names in the database. This is very similar to sp_findsp I use, which I have posted in the past off the net, but I have modified it so it gets registered as a system procedure.

So here's sp_findfields. It will return a fairly printable representation of the results of all fields which match the passed in string. It's registered as a system procedure in this script, so it is accessible to all databases.

Usage:

sp_findfields '%Contact%'

This will find all fields with the string 'Item' in it. Note you need to provide the wildcard characters.

USE master
GO

IF (SELECT OBJECT_ID('sp_findfields','P')) IS NOT NULL
    BEGIN
        DROP PROCEDURE sp_findfields
    END
GO

CREATE PROCEDURE sp_findfields
(@searchText varchar(50))
AS
BEGIN
    
    SELECT SchemaName = LEFT(TABLE_SCHEMA,10),
        TableName = LEFT(TABLE_NAME, 35),
        FieldName = LEFT(COLUMN_NAME, 40),
        DataType = LEFT(DATA_TYPE, 13),
        DataSize = CHARACTER_MAXIMUM_LENGTH,
        AlloysNulls = IS_NULLABLE
    FROM INFORMATION_SCHEMA.columns
    WHERE column_name like @searchText
    ORDER BY TableName, FieldName
END
GO

--Mark procedure as system object
EXEC sys.sp_MS_marksystemobject sp_findfields
GO


GRANT EXEC ON sp_findfields TO public
GO

Tuesday, September 01, 2009 5:10:15 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Saturday, August 29, 2009

The following code snippets make retrieving values from DataRows safely, and properly casts them to the desired values.

 

        /// <summary>

        /// Gets the int value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <returns></returns>

        public static int GetIntValueFromDataRow(string fieldName, DataRow dr)

        {

            return (dr[fieldName] == DBNull.Value ? 0 : Convert.ToInt32(dr[fieldName].ToString()));

        }

 

        /// <summary>

        /// Gets the int value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <param name="defaultValue">The default value.</param>

        /// <returns></returns>

        public static int GetIntValueFromDataRow(string fieldName, DataRow dr, int defaultValue)

        {

            return (dr[fieldName] == DBNull.Value ? defaultValue : Convert.ToInt32(dr[fieldName].ToString()));

        }

 

        /// <summary>

        /// Gets the string value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <returns></returns>

        public static string GetStringValueFromDataRow(string fieldName, DataRow dr)

        {

            return (dr[fieldName] == DBNull.Value ? String.Empty : dr[fieldName].ToString());

        }

 

        /// <summary>

        /// Gets the string value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <param name="defaultValue">The default value.</param>

        /// <returns></returns>

        public static string GetStringValueFromDataRow(string fieldName, DataRow dr, string defaultValue)

        {

            return (dr[fieldName] == DBNull.Value ? defaultValue : dr[fieldName].ToString());

        }

 

        /// <summary>

        /// Gets the bool value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <returns></returns>

        public static bool GetBoolValueFromDataRow(string fieldName, DataRow dr)

        {

            return (dr[fieldName] == DBNull.Value ? false : Convert.ToBoolean(dr[fieldName].ToString()));

        }

 

        /// <summary>

        /// Gets the decimal value from data row.

        /// </summary>

        /// <param name="fieldName">Name of the field.</param>

        /// <param name="dr">The dr.</param>

        /// <returns></returns>

        public static decimal GetDecimalValueFromDataRow(string fieldName, DataRow dr)

        {

            return (dr[fieldName] == DBNull.Value ? 0 : Convert.ToDecimal(dr[fieldName].ToString()));

        }

Saturday, August 29, 2009 7:32:59 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, August 28, 2009

I am a huge fan of CodeSmith. If you are not familiar with it, and you do any amount of coding at all, you owe it to yourself to check it out.

Below is some template code which loads the foreign keys of a table into a Dictionary object. It stores the name of the table and foreign key field name. As you can see, it generates a notice when it comes across a recursive relationship.

 

public Dictionary<string,string> GetForeignKeyTables()
{
    Dictionary<string,string> dic = new Dictionary<string,string>( );

 for (int idx = 0; idx < SourceTable.ForeignKeys.Count; idx ++)
 {
        string primaryTable = String.Empty;
        string primaryKey = String.Empty;

  // To get the foreign key columns
  ColumnSchema col1 = SourceTable.ForeignKeys[idx].ForeignKeyMemberColumns[0];
        primaryKey = col1.Name.Trim();

  // To get the foreign key tables
        primaryTable = SourceTable.ForeignKeys[idx].PrimaryKeyTable.ToString().Replace("dbo.",String.Empty).Trim();
        if (!dic.ContainsKey(primaryKey))
            dic.Add(primaryKey, primaryTable);
        else
            MessageBox.Show("This table may contain recursive relationships. You must set those relationships up manually.");
    }

    return dic;
}

 

Friday, August 28, 2009 10:48:39 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, August 27, 2009
Interview question -- non-technical about how I handle release problems.
Thursday, August 27, 2009 12:01:11 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, August 25, 2009
An example of reflection in coding!
Tuesday, August 25, 2009 6:12:16 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Monday, August 24, 2009

Question: What's reflection, and how have you used it to solve a problem?

Answer: Reflection is a way to look at assembly metadata and look in and see what is contained. It also allows you to use late binding and call methods within those assembles.

For the second part, a simple explanation is all you need to show that you understand how it is used.

So what if you've enver used reflection? First, shame on you (kidding!). It DOES serve a very important purpose and allows for some great solutions, especially at an architectural level. If you've never used it, I recommend immediately trying it out, and you'll find many, many uses. Here's a tutorial I found that looks decent. That way, when asked this question (and I get this one a lot) you can answer how you *might* really use it. Honestly, you've probably used it and didn't realize it if you've added certain attributes to your code.

I have used reflection for everything from identifying certain classes and functions. For example, for a coding sample, I used LINQ for Reflection and attributes to identify classes which supported certain calculations. By doing this, I could add more functions dynamically and the UI would pick it without changing code. Since LINQ for Reflection is not discussed much, I'll post some about that later.

There are some costs associated with Reflection though. Speed! Late Binding is slower by it's nature, as well as all the processing looking for methods, so plan and use wisely!

Monday, August 24, 2009 3:27:02 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, August 21, 2009
Another interview question of the day -- Access Modifiers
Friday, August 21, 2009 5:06:04 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, August 19, 2009
Another interview question du jour!
Wednesday, August 19, 2009 8:34:53 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, August 18, 2009

I've been doing technical interviews for about 5 years now for .Net, and hired a lot of developers in that time. As a result, I have become proficient at quickly assessing a level of technical expertise as well as how a developer may fit within an organization. I will blog another time about what characteristics I look for in a candidate, but for now, I will go through some of the technical questions I ask, answer them, and explain why I ask the question.

Question: What's the difference between an abstract class and an interface

Answer: They have some similarities in that they both define abstract members which have to be implemented. An interface is really just a contract where you are stating "if I implement this interface, I will implement these methods". However, an abstract class can have an implementation, where an interface cannot. An abstract class can also have constructors and field data.

One advantage of an interface is that you can implement more than one interface per class, but you can only inherit from one class.

Note there's a lot more you could talk about with them both (and you don't want to overtalk any question), but the above will demonstrate you have a good knowledge of OOP design, which is what I was looking for. It's surprising how many developers cannot get this question right.

To learn more, here's a good article which discusses them in more detail (more than you'd need to answer the question for sure, but good knowledge to have!)

Tuesday, August 18, 2009 4:02:10 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Monday, August 17, 2009
I highly recommend the Application Architecture guide from CodePlex.
Monday, August 17, 2009 1:21:50 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Saturday, August 15, 2009

I needed to use LINQ to XML to grab some RSS feed information into a BusinessObject I created to save to a database. Here's what I needed:

var activityList = from e in doc.Descendants("item")

                                       select new RubiconPortal.BusinessObjects.Activity

                                       {

                                           ActivityTypeID = ActivityTypes.Blog.Code,

                                           ActivityDate = e.Element("pubDate").Value.RSSDateTime().ToShortDateString() + " " + e.Element("pubDate").Value.RSSDateTime().ToShortDateString(),

                                           ActivitySummary = HttpUtility.HtmlDecode(e.Element("title").Value),

                                           ActivityDetailsURL = e.Element("link").Value

                                       };

 

Since the pubDate comes across in a format which is different than I wanted, I decided to write an extension method called RSSDateTime() to convert to a DateTime, from which I can format any way I want or work with. Here's the method:

 

public static DateTime RSSDateTime(this string date)

        {

            DateTime d;

            if (DateTime.TryParse(date, out d))

            {

                return Convert.ToDateTime(date);

            }

 

            return DateTime.Now;

 

        }

Saturday, August 15, 2009 9:18:49 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, August 14, 2009

Tonight was a very enjoyable night of coding. I created the first phase of my "activity aggregator". I actually had a more clever name for it, but being tired, it slips my mind right now.

Currently, I post several places.. short updates for on Twitter. Longer discussions end up on here, my blog. I have some other sources I plan on integrating over time, such as links I found useful (similar to Digg, but also where I can place why I found it useful). That means growth, and when it comes to design, it's best to design change into it up front.

The first thing I needed to do was create my table and business object to collect these activities. In my table, I store ActivityDate, what type of activity it was (foreign key to another table -- ActivityType), a brief summary of the activity text, and finally the url someone interested could click on to get more information. The internal members of my activity class look like this:

   15         #region Private Members

   16 

   17         private int activityID;

   18         private int activityTypeID;

   19         private string activityDate;

   20         private string activitySummary;

   21         private string activityDetailsURL;

   22 

   23         #endregion

 

Each private member has a publically exposed property.

 

Most of my activities will have XML feeds, such as the RSS feed of my blog, and the Twitter API. Therefore, I enforce a similar implementation by creating an abstract base class, called BaseFeed, which looks like this:

    1 using System.Xml.Linq;

    2 using RubiconPortal.Common;

    3 

    4 namespace RubiconPortal.BusinessObjects

    5 {

    6     internal abstract class BaseFeed : BaseClass

    7     {

    8 

    9         public abstract int ParseFeed(XDocument doc);

   10 

   11     }

   12 }

 

So now I have a "contract" that I need to use to have a similar method for any activity I want to log. I could have used an interface for this, since there's no true implentation here, and I may refactor it later to do so, but I do have some ideas where I may want to provide some implementation, so that's why I chose an abstract class.

 

So the first item I wanted to do was implement capturing my Twitter posts in this activity, since I currently don't have a way to capture and post them on my site. I will add the rest of the activities later. In a previous post, I described how I took the Yedda Twitter API and modified it to return XDocuments, and here's another chance to take advantage of that change with LINQ.

 

When I post to my Twitter feed, I want to make sure my home page automatically reflects this activity. So I implement a TwitterFeed object, which implements the BaseFeed method ParseFeed. Using LINQ to XML, I pull out the pieces of the response I want, and populate the public properties of my Activities class, then save my activity. Here's what my TwitterFeed class looks like:

 

    1 using System;

    2 using System.Linq;

    3 using System.Web;

    4 using System.Xml.Linq;

    5 using Rubicon.Common;

    6 using RubiconPortal.Common;

    7 

    8 namespace RubiconPortal.BusinessObjects

    9 {

   10     internal class TwitterFeed : BaseFeed

   11     {

   12         public override int ParseFeed(XDocument doc)

   13         {

   14             try

   15             {

   16                 if (doc != null)

   17                 {

   18                     var activityList = from e in doc.Descendants("status")

   19                                        select new RubiconPortal.BusinessObjects.Activity

   20                                        {

   21                                            ActivityTypeID = ActivityTypes.Twitter.Code,

   22                                            ActivityDate = (e.Element("created_at").Value.ParseDateTime()).ToShortDateString() + " " + (e.Element("created_at").Value.ParseDateTime()).ToShortTimeString(),

   23                                            ActivitySummary = HttpUtility.HtmlDecode(e.Element("text").Value),

   24                                            ActivityDetailsURL = "http://twitter.com/" + e.Element("user").Element("screen_name").Value

   25                                        };

   26 

   27                     foreach (RubiconPortal.BusinessObjects.Activity item in activityList)

   28                     {

   29                         item.Save();

   30                     }

   31                 }

   32 

   33                 return ReturnCode.Success.Code;

   34             }

   35             catch (Exception ex)

   36             {

   37                 ErrorHandler(ex, "An unexpected error occurred in TwitterFeed.ParseFeed() - " + ex.Message);

   38                 return ReturnCode.Failure.Code;

   39             }

   40         }

   41 

   42     }

   43 

   44 }

 

Within the ParseFeed method I am using LINQ to XML to populate my business object calling the save() method to write it to the database. As you can see, using LINQ to XML can be a lot simpler than using XML/XPath. Once in the database, I can query it in my user control, and display it on my home page here.

 

Now, when I make my Twitter post, all I need to do is take the XDocument the Twitter API returns, and pass it into the ParseFeed method, which looks like this...

   35                     //Post my tweet to Twitter

   36                     TwitterAPI twit = new TwitterAPI();

   37                     XDocument doc = twit.UpdateAsXML(Settings.TwitterUserName(), Settings.TwitterPassword(), txtPost.Text);

   38 

   39                     //Save it to the activity table for displaying the activity

   40                     TwitterFeed feed = new TwitterFeed();

   41                     feed.ParseFeed(doc);

 

Simple and neat! Now when I implement it for my blog, it will be just as quick and easy!

 

Props go out to this post I snagged an extension method for formatting the Twitter posting date to something a human can use (and my C# class can use to manipulate and save!)

 

 

 

Friday, August 14, 2009 7:40:31 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, August 12, 2009
Some tools I downloaded today which appear VERY useful, and touching on the ORM topic.
Wednesday, August 12, 2009 6:31:11 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, August 11, 2009

Tonight I didn't get as much time to work on the site as I would have liked, so I focused on getting the admin pages up on the production server so I could do some "behind-the-scenes" work remotely. This required some security, which I started last night, but the data migration for that was a bit more daunting, so I needed to finish it tonight. While the authentication providers and controls do handle a LOT, it has an interesting learning-curve, and deployment can be a challenge as well. All-in-all, it sure beats writing all that code by myself.

I tried to use a lot of caching and cached settings to help improve the performance on certain pages, especially my client list. On my admin pages, I made sure to create a means to reset that cache without having to do a complete server reset. Actually, the same approach I took would work well for high availability sites, as the method I used to complete this would not require a server reset to re-load systems. When I was int he banking industry, high-availability was a huge issue, and simple config changes meant waiting for a scheduled system outage or worse, an emergency outage. When I redesigned that site, that was one of the top priorities I had.

It occurred to me how much time it takes to set up the infrastructure of a site: master pages, common libraries, configuration files, CSS, etc. Once those are done, if done properly, the rest of the site should go fast. One thing I have found to speed that up was the use of Visual Studio Project Templates. Combined with code generation like CodeSmith, you can really generate web sites extremely fast, and get on to coding the "fun" items. I will write about both of those in the future (CodeSmith and Project Templates) once the site is stabilized.

Tomorrow night may not have a lot of development, as my parents will be in town. Later this week, I will be coding my next control: the activity feed. When posts and feeds are made or read, this control will snag it, and place a brief "teaser" on the home page.

Tuesday, August 11, 2009 6:05:59 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, August 07, 2009
A plug for my company, Rubicon Computing Solutions, LLC.
Friday, August 07, 2009 6:02:11 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, August 05, 2009
Using LINQ to XML to work with the Twitter response, and modifying the Yedda Twitter API wrapper.
Wednesday, August 05, 2009 6:34:05 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, August 04, 2009

Note: For visitors of your site, this entry is only displayed for users with the preselected language English (United States)/English (United States) (en-US)

How the VS2008 IDE is very helpful to conditional compilation, and also how the site is coming along

Tuesday, August 04, 2009 6:15:10 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, June 13, 2006
New Data property of the Exception class is quite useful!
Tuesday, June 13, 2006 4:42:38 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [2]  | 
# Tuesday, May 16, 2006
Get the name of the current db in t-sql
Tuesday, May 16, 2006 4:38:30 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 
# Friday, April 28, 2006
A new blog...
Friday, April 28, 2006 4:38:06 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, March 21, 2006

Is it just my installation, or is WinCV missing from the latest version of .Net? Granted, I can still use the old WinCV by changing the config file, but why was such a useful tool pulled from VS2005?

If you've never used WinCV, check it out for VS2003 and prior version. It essentially lets you search the framework for a certain keyword. For example, if you want to find out which namespace "Registry" is in, type it in, and see the entire implementation. By using the configuration file, you can add additional assemblies for WinCV, to search your own libraries or those of third party vendors.

 

Tuesday, March 21, 2006 1:48:01 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Tuesday, March 14, 2006

Just a little tip, as I didn't read the error message generated as closely as I should have. I was working this weekend on the Microsoft Code Template for Building a Provider Based Feature and was migrating some existing libraries I had for VS2003 to take advantage of the features in VS2005.

First, let me say I love things in VS2005 like Generics, and the implementation of the Provider Model. I was migrating my data access libraries and error handling libraries, and was setting up some tests in nUnit as part of ongoing testing. Although I haven't changed my data and error handling models in a long time, I figured it was a great design idea to be able to change them dynamically using the Provider Model.

To make a long story short, I was running my tests for the data library, and when I invoked my Data Access classes, I was getting a "TypeInitializationException" error. I checked and double-checked my configuration file, and it appeared to all be correct. I looked at the InnerException, and it didn't seem to be much more help. However, I went further to look at the InnerException of the InnerException, and there's where I found the solution. The Rosetta Stone?

  • Only one <configSections> element allowed per config file and if present must be the first child of the root <configuration> element.

A quick check indicated that I hadn't made the configSection the first element. Doh!

So there are a few lessons to learn here. 1) Make sure your configSections is first (normally not a problem, just a cut and paste issue here) and 2) Make sure you dig REAL deep into the InnerExceptions for the details and 3) the new Visualizers in vs2005 were too cool and very helpful.

Hats off to the VS2005 IDE team! It's spawned a few visualizers I can think of, so if time permits in the future, I will be publishing those right here!

Tuesday, March 14, 2006 5:52:31 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, October 07, 2005
..or why MS has once again dropped the ball on it's core developer community.
Friday, October 07, 2005 4:57:27 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 
# Tuesday, September 20, 2005
"Internal Query Processor Error: The query processor could not produce a query plan. Contact your primary support provider for more information" when passing in C# DateTime value...
Tuesday, September 20, 2005 11:50:34 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, May 27, 2005
(and maybe why Extreme Programming (XP) is also bad?)
Friday, May 27, 2005 6:28:46 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
Need a good developer?
Friday, May 27, 2005 12:33:35 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [2]  | 
Tired of cutting and pasting? Try CodeSmith...
Friday, May 27, 2005 12:19:32 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 
# Saturday, April 23, 2005
What the $*#(U$(? Where did the wse version go?
Saturday, April 23, 2005 9:36:27 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, April 14, 2005
I am joining the fray....
Thursday, April 14, 2005 5:49:54 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 
# Monday, April 04, 2005
How to get them to reappear...
Monday, April 04, 2005 7:28:35 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 
# Monday, March 21, 2005

Let's talk resume's for a minute. You want that interview don't you? Well, sometimes all you have to get you there is your resume (although personal reference is the best way if you can get it, an area where networking and doing quality work can help).

There's a million places on the internet to help you decide how to structure your resume. I have only gotten one criticizm from my resume, and I am not sure if it's the content or the structure which works best. But here's a couple of pointers which I think have helped out my resume.

  1. Place a logo of any certifications you have if available (e.g. MCSD). These are real eye catchers. Make the images small though..
  2. Place your specific skills separate from your experience, preferably near the top. This makes it easy to survive the first pass from the recruiter/manager.
  3. Sell yourself! Research “power“ words and make any experience descriptions short and chock full of those words.

Now, there's a few easy tips of what to do. I have been helping staff for years, and here's some of the gems I have seen.

  • Horrible writing and spelling.
  • Obviously exagerated skills and experiences (4 years experience, 10 years at a certain skill)
  • Never say you are an expert at anything, even if you are. Humility goes a long way, and if the interviewer knows more, you'll be humbled by them, as I witnessed in the past week.
  • Use nice paper if submitting a hardcopy (I received one handwritten on a partial piece of paper -- I kid you not)

It's not tough... just use some common sense!

Monday, March 21, 2005 3:11:00 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Saturday, March 19, 2005
OK, so now you know wht might be asked.. how not to blow it.
Saturday, March 19, 2005 12:14:50 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Friday, March 18, 2005
WTF? Poor documentation...
Friday, March 18, 2005 9:15:58 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [4]  | 
# Thursday, March 17, 2005
wow... what was that? Some observations from helping with some technical interviews.
Thursday, March 17, 2005 8:19:01 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [3]  | 
# Wednesday, March 16, 2005
When you need to uniquely identify a file using the time and date stamp, use this!
Wednesday, March 16, 2005 3:26:57 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [3]  | 
# Friday, March 11, 2005

Someone asked me today if I knew that you couldn't use GETDATE() in functions in SQL Server. Well, I did, so I dug out this solution I had found a while back, and decided to post it, since I am sure others have come across the same issue.

Basically, you use a view to do the work for you... here you go!

CREATE VIEW Function_Assist_GETDATE

/********************************************************
*
* A view to return one row, with one column, the current
* date/time from the built-in function GETDATE().  This
* view allows a UDF to bypass the restriction on access to
* the non-deterministic getdate() function.
*
* Attribution: Based on a newsgroup posting in by Mikhail
*   Berlyant in microsoft.public.sqlserver.programming
*
* Common Usage:
DECLARE @dtVar datetime
select @dtVAr = [GetDate] from Function_Assist_GETDATE
**********************************************************/

AS
    SELECT getdate() as [GetDate]

GO

GRANT SELECT on Function_Assist_GETDATE to PUBLIC
GO

Friday, March 11, 2005 9:45:00 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, March 09, 2005
Exception handling analyzed...
Wednesday, March 09, 2005 5:47:50 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Friday, December 31, 2004
Clearing up the confusion when you need the return value from an insert.
Friday, December 31, 2004 3:25:39 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Thursday, December 30, 2004
Finding all tables where a field exists in SQL Server
Thursday, December 30, 2004 6:09:49 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [2]  | 
# Tuesday, December 28, 2004
How to format a date to a particular format...
Tuesday, December 28, 2004 5:07:14 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Monday, December 27, 2004
How to quickly find out which control caused the postback
Monday, December 27, 2004 10:19:36 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [4]  | 
# Tuesday, December 21, 2004
How to step through your client side code
Tuesday, December 21, 2004 9:26:19 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [2]  | 
# Monday, December 20, 2004
The vb function in C#
Monday, December 20, 2004 9:13:55 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Saturday, December 18, 2004
Just a tip to remind myself
Saturday, December 18, 2004 9:55:17 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, December 15, 2004
A brief look into the System.Diagnostics namespace...
Wednesday, December 15, 2004 8:15:13 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [4]  | 
# Saturday, December 11, 2004
A costly mistake to forget...
Saturday, December 11, 2004 6:29:51 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Wednesday, December 08, 2004
How to cast to a specific type if you have the string value of the type
Wednesday, December 08, 2004 2:49:20 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [3]  | 
# Monday, December 06, 2004
Quick fix for a "catastrophic" problem!
Monday, December 06, 2004 4:44:29 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Thursday, December 02, 2004
Well lookie what else it can do!
Thursday, December 02, 2004 5:42:28 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Tuesday, November 30, 2004
Let's work with an enum today!
Tuesday, November 30, 2004 5:11:10 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
A useful port from something in the old VB6 days...
Tuesday, November 30, 2004 5:05:16 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Monday, November 29, 2004
Save the day!
Monday, November 29, 2004 6:16:26 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
Hot keys and aliases, oh my!
Monday, November 29, 2004 4:36:57 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Saturday, November 27, 2004
A quick function to convert an integer to a Roman numeral
Saturday, November 27, 2004 4:25:01 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [2]  | 
# Tuesday, November 23, 2004
Follow me as I configure a client in automated builds
Tuesday, November 23, 2004 9:47:25 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Sunday, November 21, 2004
How to configure log4net to save entries into the database
Sunday, November 21, 2004 4:05:01 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [2]  | 
# Friday, November 19, 2004
How to make an ASP.Net page expire
Friday, November 19, 2004 2:40:51 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, November 17, 2004
How to break on an error in ASP.Net
Wednesday, November 17, 2004 3:29:26 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [3]  | 
# Thursday, November 11, 2004
Changing the look of thinks client side dynamically...
Thursday, November 11, 2004 5:05:03 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [0]  | 
# Wednesday, November 10, 2004
How to search all those assemblies and find just what you need...
Wednesday, November 10, 2004 4:47:53 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Tuesday, November 09, 2004
CodeLib from fish
Tuesday, November 09, 2004 5:34:42 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Monday, November 08, 2004
Allows you to capture the click, dblclick, etc to make a normal form control read only.
Monday, November 08, 2004 4:47:19 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
How to dynamically change the EntType of an HTML form...
Monday, November 08, 2004 4:40:15 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [2]  | 
# Saturday, November 06, 2004
When you can't create a SQL diagram, use this to print usable field information
Saturday, November 06, 2004 4:45:22 PM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
How to add client-side javascript to individual listItems in a RadioButtonList
Saturday, November 06, 2004 5:31:28 AM (GMT Standard Time, UTC+00:00)  #    Disclaimer  |  Comments [1]  | 
# Thursday, October 21, 2004
How to grab a random record which is very useful for testing...
Thursday, October 21, 2004 6:58:16 AM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [2]  | 
# Tuesday, October 19, 2004

DBA Must Haves (IMHO)

First, a little about myself. I have been working with databases since SQL Server 6, and a little back when it was Sybase. Here are two procs I use so much, I have to link them here.

First, there's Narayana Vyas Kondreddi's sp_generete_inserts. It's a great utility/sproc for extracting data from existing tables. I have used it from everything from migrating data to making impromptu backups to text files, all the way to bailing out some hapless developers who run against production and wipe out data they should not be touching. Here's where you can get it:

http://vyaskn.tripod.com/code/generate_inserts.txt

Next, there's sp_findsp. Not the prettiest thing, but if I want to find out where a string (such as a table or proc) is used, I can run this baby and it will return to me a list where I can start looking. It's also very useful to me when I start a new project to do some “mining“ to see what's going on. Here's where this one can be found:

http://databasejournal.com/features/mssql/article.php/1458871

These two follow me everywhere I go!

 

Tuesday, October 19, 2004 3:07:53 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [1]  | 

Note: For visitors of your site, this entry is only displayed for users with the preselected language English/English (en)

Want a good tip?

Tuesday, October 19, 2004 2:55:14 PM (GMT Daylight Time, UTC+01:00)  #    Disclaimer  |  Comments [3]  |