Saturday, December 29, 2007
Getting SQL 2005 Column information for field validation
USE AdventureWorks
GO
SELECT C.Table_Name, C.Column_Name, C.Ordinal_Position, C.Column_Default, C.Is_Nullable, C.Data_Type, C.Character_Maximum_Length, C.Numeric_Precision, C.Numeric_Scale, C.DateTime_Precision
FROM information_schema.columns C
JOIN Information_Schema.Tables T ON C.Table_Name=T.Table_Name
WHERE Table_Type = 'Base Table'
ORDER BY C.table_name, C.Ordinal_Position
Hope that helps.
Joe Kunk
Okemos, MI USA
Tuesday, December 11, 2007
Use a CheckBox instead of a ToggleButton for .Net windows form
Turns out that if you need this effect on a .Net winform, use the CheckBox control and set the Appearance property to "Button". The button appears "down" when Checked is true. Simple question, simple answer (once you find it).
Hope that helps.
Joe Kunk
Okemos, MI
USA
Saturday, December 08, 2007
Post-build event command line
I want to keep the freshly built plugin.dll and plugin.pdb files in the standard Visual Studio project build folder to be consistent with other projects, but it is a pain to manually copy those two files to the application's reserved folder after each build.
As typical in Visual Studio, when you think "there must be a better way", there usually is.
Go to the project properties, Build Events, and specify a post-build event command line that copies the freshly built assembly to the desired location. Thus it will just automatically be placed there after each successful build. You have the option to execute the post-build event command line even if the build is not successful.
The event command line can be any command that will execute properly in the operating system's command line interface (File, Run, Cmd {enter}). For more complex tasks, you can call a batch file or even a console project executable in your solution.
If the build event fails, your build will fail as well. This is a good thing since you want to be sure that your post-build event completed successfully. A pre-build event command line is available too.
The single line command that i used is below. The /y parameter overwrites any existing file of the same name without prompting. It uses pre-defined project constants that are listed for you when you are in the editor box of that property page. Visual Studio refers to them as "macros".
{commercial software reserved folder location} refers to the specific reserved plugin folder of the software. Note the use of quotes since the build path and destination path may both contain spaces. Note that the macros will expand properly even within quoted strings.
copy /y "$(TargetName).*" "C:\Program Files\{commercial software reserved folder location}\"
Hope that helps.
Joe Kunk
Okemos, MI
USA
Monday, October 29, 2007
Quick method to initialize a strongly-typed DataRow in C#
This code is not comprehensive of all the possible data types, but it did the trick for me:
private void InitializeNewDataRow(DataRow dr, System.Data.DataColumnCollection dcs) {
object[] fields = dr.ItemArray;
DataColumn[] dca = new DataColumn[fields.Length];
dcs.CopyTo(dca,0);
for (int i=1; i < fields.Length; i++) {
if (dca[i].DataType == typeof(int)) fields[i] = 0;
if (dca[i].DataType == typeof(Int16)) fields[i] = 0;
if (dca[i].DataType == typeof(Int32)) fields[i] = 0;
if (dca[i].DataType == typeof(Int64)) fields[i] = 0;
if (dca[i].DataType == typeof(bool)) fields[i] = false;
if (dca[i].DataType == typeof(string)) fields[i] = string.Empty;
if (dca[i].DataType == typeof(decimal)) fields[i] = 0.0;
if (dca[i].DataType == typeof(DateTime)) fields[i] = DateTime.MinValue;
}
dr.ItemArray = fields;
}
Hope it helps.Joe Kunk
Monday, October 08, 2007
Server and PC virtualization as a Disaster Recovery strategy
I spent a stint as a Information Technology Director several years ago. One of the difficult challenges that I faced was implementing a viable disaster recovery plan to protect the business and ensure continued operations in the event of any kind of business interruption.
The best option available at the time was to contract with a firm that would provide compatible servers and PCs within a specified timeframe in the case of a business interrruption - basically a mobile computer center in the back of a semi-truck. Using recent off-site backup tapes, we would recreate our computing environment and continue to operate.
My concern was that backup tapes and off-site tape procedures are often less than 100% reliable. The slightest error on one of the tapes could invalidate the restore. Differences between the supplied hardware and that used in-house could adversely affect the operation of the server. While test sessions were available from the vendor to help ensure that everything was ready to go prior to an interruption, there was always the knowledge that bringing up a duplicate server/PC environment would be difficult and time-consuming under the best conditions. To be clear, I was much more concerned about successfully recreating the server environment than the end-user PC environment.
The reason for this post is to point out that server and PC virtualization software systems have advanced to the point that they can serve as the basis for a new and more effective approach to disaster recovery. I won't mention vendor or product names but a quick Internet search for "server virtualization" will provide the current list.
In a nutshell, virtualization software allows the creation of a virtual machine image that represents all the resources of a computer as a single file or collection of files, including the hardware, operating system, disk drives, applications, data, etc. The host application loads and runs the virtual machine and allocated physical resources among the virtual machines.
This layer of virtualization does have a performance penalty but with the latest multi-core servers and PCs available, it can be a minor concern.
Now consider this. What if you implemented all your daily production servers in your data center as virtual servers such that that actual physical servers rarely ran more than the virtualization software?
Virtual server backup simply becomes a file copy to an external disk drive device. One Terabyte (1,000 Gigabyte or 1 million Megabyte) external drives are available now for just a couple hundred dollars each. By rotating backups among at least two external drives, you always have your latest server backup off site.
Most PC users will not want to work inside a virtual machine image on a regular basis. It is best to create a master end-user PC configuration that has all the necessary software installed and properly configured. This configuration can be written to an image file by software designed to provide hard drive cloning and restored onto a client PC when needed. Restoration tends to be fast and has the advantage of providing a uniform end-user starting point for the disaster recovery environment.
Under this scenario, disaster recovery becomes much more viable since to get properly running servers, all you have to do is get any sufficiently powerful server that can run the virtualization host software, load and run the saved server virtual machine file, and you're up! You are no longer dependent on getting server hardware in an emergency that is configured exactly as your in-house servers. In my opinion, this can make the difference between a successful disaster recovery scenario and one that is disappointing at the least.
Attach a couple PCs that have been updated with the reference end-user configuration image, and you are up and running in your own business environment, just the way that you are used to seeing it.
I am no longer responsible for implementing this kind of strategy but it just makes so much sense to me that I wanted to share it in hopes that it can be beneficial to those that are facing this challenge yet today.
Hope it helps,
Joe Kunk
Friday, October 05, 2007
WOW! - Microsoft to Release the Source Code for the .NET Framework Libraries
For more information, see his post at http://weblogs.asp.net/scottgu/archive/2007/10/03/releasing-the-source-code-for-the-net-framework-libraries.aspx.
Joe Kunk
Thursday, October 04, 2007
Dynamically create a simple array in VB.Net
For example, to create a string array of 5 elements (0 to 4):
Dim MyArray as System.Array
MyArray = System.Array.CreateInstance(GetType(String),5))
which is equivalent to the following code at compile time:
Dim MyArray(4) as String
The same technique can be used to dynamically create arrays of any type at runtime.
Note that the above example assumes Option Strict is off. If Option Strict is on, you must use the .SetValue and .GetValue methods to access the array elements. If Option Strict is on, a proper code sample would be:
'Option Strict On
Dim mya As System.Array
mya = System.Array.CreateInstance(GetType(String), 3)
mya.SetValue("Word1", 0)
mya.SetValue("Word2", 1)
mya.SetValue("Word3", 2)
MessageBox.Show("Element (2) is " & _
Convert.ToString(mya.GetValue(2))) 'Returns "Word3"
Hope that helps.
Joe Kunk
Sunday, August 19, 2007
A public Thank You! to Jeff McWherter
On the morning of our last meeting on 8/16, our scheduled speaker sent an email in the morning that he had the flu and could not make the meeting. With only hours left until the meeting, Jeff McWherter of A.J. Boggs, Inc. kindly offered to do a presentation on ASP.Net Performance and Optimization. As we got to the meeting, I found out that he suffered a hard-disk crash that morning and was forced to reinstall Visual Studio and also finish the presentation.
Despite these challenges, he gave a very interesting presentation that was well received by the audience. We all learned some very valuable lessons. Jeff is a Board Member of GLUGnet and this is just another example of how he contributes so much to the group and we all benefit from it.
Great job Jeff! Thank you so much!
Joe
Thursday, August 16, 2007
GLUGnet Meeting Wednesday August 16, 2008 - ASP.Net Optimization
Where: 1145 Engineering Building, Michigan State University, East Lansing, Michigan
When: Thursday August 16th 6:00-8:00 PM
What: Free swag including Spices.net Suite, Telerik Rad Controls for Winforms,Telerik Reporting, FarPoint Spread for Windows, FarPoint Spread for Web, DevLink conference pass, free pizza and more.
Topic: Optimizing and Performance Tuning your ASP.net Applications
Speaker:
Jeff McWherter is the Director of Software Development at A.J. Boggs and Company in Okemos, MI. He graduated from Michigan State University with a degree in Telecommunications and Computer Science, and has twelve years of professional experience in software development. He is a founding member and current Program Director for the Greater Lansing Users for .NET (GLUG.net). He enjoys profiling code, applying design patterns, finding obscure namespaces, and long walks in the park. His lifelong interest in programming began with a Home Computing Magazine in 1983, which included an article about writing a game called Boa Alley in BASIC. www.glugnet.org
Friday, August 03, 2007
Easy and effective desktop publishing / page layout software
I am once again putting together a flyer this weekend and I am back to using the latest version of the same program that has always worked very well for me in the past and still works just great.
It is such an impressive solution and great piece of software that I want to give it some much deserved public credit with this blog entry. If you ever have the need to go beyond Microsoft Word to get a nice looking document, you likely can't go wrong by checking out PagePlus X2 by Serif Ltd.
Hope that helps,
Joe Kunk
Wednesday, July 18, 2007
Greater Lansing User Group .net (GLUGnet) July 2007 Meeting
When: Thursday July 19th 2007 6:00-8:00 PM
What: We always have give away hundreds or thousands of dollars worth of swag along with free pizza and pop for everyone. This month we will also be announcing the opening of the Flint branch and our Vice President Vivek has secured all our membership 100 MB of free hosting from Verio.
Nationally known Julie Lerman will be our first female speaker. She will be presenting on ADO.NET Entity Framework.
Visit our website for more details: www.glugnet.org
Wednesday, July 11, 2007
Windows Server® 2008, Visual Studio® 2008 and Microsoft SQL Server™ 2008 Joint Launch Announced
For more info, click here .
Joe Kunk
Friday, June 22, 2007
.Net in-memory data table can have columns of any data type
Joe Kunk
Saturday, February 03, 2007
Basics.Net: Structures
Each of these logically represent a single value, are a fixed size in memory of 16 bytes or less, are kept on the high-performance stack, and the assignment of the value to another variable makes another copy of the data.
A very useful extension of the value type is the known as a Structure (VB.Net) or struct (C#). These are essentially custom classes that, like all classes, can have constructors (the new operator), public/private properties, and public/private methods. The private variables within the structure must consist solely of value types and not exceed 16 bytes total in size.
Like primitive value types, structures logically represent a single value, are a fixed size in memory of 16 bytes or less, are kept on the high-performance stack, and the assignment of the value to another variable makes another copy of the data.
Structures allow you to create high-performance single-value custom data types with custom behaviors and characteristics enforced by its methods and properties. Structures can be combined in a [reference type] custom class to create a rich application object.
For example, an Employee class might contain a structure for Age that enforces a minimum value of zero and maximum value of 100, a structure for zip code that enforces a valid U.S. zip code, a structure for email that enforces a properly formatted email address, etc. You may wish to create a library of common structures to be used by multiple applications.
Finally, below is an source code example of a simple structure, a more complex structure, and and example of using them both. The source code is presented in both C# and VB.Net.
Click here to view C# Struct Code:
Click here to view the C# Code to use the struct:
Click here to view the VB.Net Structure Code:
Click here to view theVB.Net Code to use the structure:
Back to Basics
That said, many of our members are newer to the .Net platform and would appreciate and benefit from more introductory material to help them successfully traverse what is clearly a substantial learning curve. The curse of a rich framework and a sophisticated development environment is that there is a lot to learn!
To address this need, I will start posting here a series of "Basics.Net" blog posts that will explain core concepts, with examples in both VB.Net and C#. These posts will be "bite-sized" in that each will cover only a single concept and can be reviewed and committed to memory in 15 minutes or less. Whenever possible, the significance of the concept will be included, making it easier to mentally organize the concept within the greater .Net concept space. I am confident that you will find these posts to be a fresh and useful treatment of the concepts.
I am happy to offer this service to our GLUGnet members or any other member of the .Net community. I am happy to accept suggestions for topics that are of interest, so please let me know of any topics or concepts that you would like to have covered.
Joe Kunk