I have been working in the IT field since 1992 and have specialized as a database professional working with Microsoft SQL Server since 1995. And have also worked with Visual Basic/MS Access since 1992 and Crystal Reports since 1995. I hold a bachelor’s degree in Computer Science from CSUS with a concentration in systems programming so I've done my share of programming in numerous languages and am a prolific coder.
I have extensive experience trouble shooting Microsoft SQL Server performance problems and developing Microsoft SQL Server views, user defined functions, stored procedures and data transfer packages (DTS) for ETL processes. I have developed and worked on thousands of SSRS and Crystal Reports and worked with many MS Access applications using it as a stand alone database or a front end for client server databases. Additional skills include; process analysis, process automation, data warehouse / reporting database design, development, modification, population and optimization, data conversion, reconciliation, consolidation and cleanup.
While completing my last 3 years at CSUS I worked as a PC technician at the California State Controllers, Systems Development Division. Upon completion of my degree, I started working as a contractor for Kaiser Permanente. During this time I worked directly with the physicians in 5 different departments writing database applications and redesigning existing applications. The applications were written in Paradox, MS Access, FileMaker Pro and Visual Basic. After I had been contracting with them for some time there was a change in the company development strategy and most new application development was moved to Oakland. Around this time I was hired as a temporary employee and placed on a team developing and maintaining an OBGYN Power Builder application.
In October of 1994, I left Kaiser for a lead programmer/analyst position at Access Health, Inc. While at Access Health I led efforts to convert 200+ flat file based Reports from IQ for Windows to Crystal Reports/Oracle, developed an MS Access/Visual Basic based report scheduler used to schedule and send over 2000 reports a month to the printers complete with cover pages including recipient lists, where clause criteria, requester information etc..
In November of 1995, after surviving a 40 percent layoff at Access Health ,I returned to Kaiser Permanente to take a full-time permanent Programmer Analyst position. In May 1997, my prior supervisor from Access Health contacted me. He was hired as a CIO for a company which purchased, serviced and sold loans and was planning to transfer their IT and data services departments to Sacramento from Baton Rouge. I accepted his offer to hire me as an analytical and technical leader to assist in the relocation. The first few months were spent working out of my home as I hired the first few employees. After a few months we moved to a new location and I began flying back and forth between the Baton Rouge and Sacramento offices to document and assess their current business processes and applications. During this period, I built an SQL Server based data warehouse/reporting environment and ETL procedures to consolidate data from an AS400 mainframe, multiple SQL Server databases, SAP and MS Access applications. I also developed, maintained and upgraded a number of database and intranet applications and worked closely with the help desk to resolve application and data related issues. In addition to these duties, I took on the job of lead reporting developer. During these years, I developed and delivered monthly reports for 10 securitizations involving contracts worth hundreds of millions of dollars.
In March of 2003 after taking some time off, I started consulting independently. Since then I have been consulting on both long-term and short-term contracts including the California Cancer Registry for 15 months and most recently at the California Pension Fund(CalPERS) for 3 years and 8 months.
Here is a check list of some of the things I like to do with an SQL Server database.
- Check to see that there are natural key unique constraints and primary keys on all tables to eliminate the possibility of duplicate records
- Review existing stored procedures and replace cursor based operations with set based operations
- Make sure there are no semi-random updates or repetitive updates. One way to ensure there are no semi-random updates is to run the population procedure to populate two copies of the same table using the same source data. If there are any data discrepancies between the data in the resulting tables then it is likely that there are semi-random updates in the population code.
- Make sure stored procedures are designed with flexible input parameters to eliminate the need for multiple procedures that perform the same basic operations. This minimizes maintenance and debugging time.
- With reporting stored procedures I like to standardize the input parameters and include a dynamic date range id.
- Set up fully automated server side tracing and execution of the index wizard to analyze and automatically apply or just email suggested index additions or deletions.
- Ensure there are statistics on all tables. Under certain circumstances the SQL Server 2000 sp_createstats function will die without an error message and not create statistics on all tables. These missing statistics need to be identified and created to ensure efficient SQL Server execution plans.
- Setup audit logging on all tables. I do this with a stored procedure that dynamically creates and applies audit log triggers on all tables and uses 2 stages to populate the final audit log table so the performance hit of full audit logging is minimized.
- To encapsulate business logic and reduce maintenance I like to create user defined functions and/or tables to perform repeatable operations. This usually involves some trade off between performance and maintenance so it must be balanced according to the needs of the company and the amount of data being processed.
Here is a link to linked-In account, my facebook site and another to my youtube site. The Youtube site is mostly youtube Jiu-Jitsu however there is a playlist of a few hours of my ad-hoc guitar improvisations.