Ready to try Google Apps for Work? Get 50% off with this coupon if redeemed by June 30, 2015. Get the full details here.
 
		I'm a technologist at heart, assisting companies best utilize the Internet to market themselves and sell their products and services online. This includes organizations as large as Google and as small as one or two individuals.
At Over The Top and Exhibit A Communications, I've programmed solutions for Google as well as at least one other company that was later acquired by Google. 
I've been CTO of an Internet SaaS company and spent my time pretty evenly between guiding the future technical strategy of the company, architecting software solutions for my dev teams, designing and running a data center to service our clients world-wide as well as being a technical evangalist/sales engineer to our media clients large and small.
I've also been Chief Photographer of the Daily Sun/Post newspaper back when it was a 5-day a week daily newspaper.
I also spent a great many years as a beach lifeguard  for the City of San Clemente as well as Jr. Lifeguard instructor and then as it's program coordinator.
Bragging rights
Private Pilot with Instrument rating and proud husband of soon to be 25 years (and counting).
 
		Ready to try Google Apps for Work? Get 50% off with this coupon if redeemed by June 30, 2015. Get the full details here.
How to access Google Apps for Work templates if you are logged into more than one account now that Google has broken the redirect. Learn the secret URL to get there now...
 
		Do your clients complain about importing .ics events into their Google Calendars? Try using a simple link instead and they will love you forever! I know I prefer working with vendors who do this versus those who don't.
Ever find yourself needing to write SQL code to run on multiple tables where one of the values in a secondary INSERT statement is dependent upon the identity value from previous insert? Well, if so, this should work for you…
[code language=”sql”]DECLARE @NewApiId int;
INSERT INTO APIs (Name, Description) VALUES (‘Social Links’,’The Social Links API, available only to corporate clients, will output a report all of the clients for the client”s ClientTypeID that includes all of the recorded social media properties’);
SELECT @NewApiId = CAST(scope_identity() AS int);
INSERT INTO ApiSubscriptions (ApiId, ClientId) VALUES (@NewApiId, 666);
select * from APIs;
Select * from APISubscriptions WHERE ClientId=666;[/code]
Pretty simple, no?
 
		Tired of watching Chrome get slower and slower every day? If you are like me, you fell in love with it’s clean, simple design philosophy and the ecosystem around it (Extensions, Apps, etc) but let’s be honest, it truly is about the speed! The slowness was largely limited to the Omnibox but also seemed to plague File Open dialog in Chrome which lead me down the road of thinking it was a problem with Chrome and my SSD drive.
According to Make Use Of blog, the folder %localappdata%\Google\Chrome\User Data\Default is the key to the problem. I’ve uninstalled, re-installed, turned off extenstions and apps, deleted caches; all to no avail. I was about to put a bullet in this ol’ dog until I stumbled on this article. I gave it a shot and it fixed it, with a few caveats.
Some things to consider when deleting the files in the folder above:
So, if you truly do want to reset your Chrome Clock back to day one, go ahead and delete the whole folder. If you want the most seamless experience when you re-open it and you haven’t previously logged into Chrome with your primary account, go ahead and do so now so that after you “nuke it from orbit”, you can restore the settings that you want.
Anyone else been frustrated to no end by Chrome over time? Let me know in the comments below.
Image courtesy of Elliot Brown at Flickr used under CC BY 2.0
If you are in the position of creating WordPress plugins for use by one or more of your clients but NOT for a wide-public audience then this is the article that will show you how to alert client sites when a plugin has been updated and allow them to update as they would any plugin hosted at Wordpress.com.
When was the last time that you thought about, and I mean truly thought about, your checkout/shopping cart page on your eCommerce site? It is amazing how many people just accept the default rather than think about it from a conscious perspective.
Ever have the need to populate a table from data that you have in a table on a different SQL server? This is a very handy thing to do when you are trying to add data to your dev or staging SQL databases from the live server.
Previously I would have exported the data from the one server and then imported that data into the new one.
Well brother (and sister) I’m her to tell you there is a better way!
Through the magic of Linked Servers (SQL Server 2005+ I believe) it can be done. And through the use of Synonyms, you can even make it less cumbersome if it is something that you do regularly.
How does this work you ask? Well here is how I did it.
exec sp_addlinkedserver [server.domain.com];INSERT INTO targetTableName ([Col1], [Col2], [Col3], [etc])
   SELECT [Col1], [Col2], [Col3], [etc]
      FROM [server.domain.com].databaseName.dbo.tableNameCREATE SYNONYM nickname FOR [server.domain.com].databaseNameOf course, your results may vary, always test on a backup database, blah, blah blah. Enjoy coders!
I have been working around some issues with Wget recently and after modifying the URLs, I found that it would start failing if the URL was a querystring with more than one variable. This means that you would have an & in the string.
Well, Wget sees this as an additional command so you need to delimit it somehow. Googling turned up this article that indicates either enclosing the URL in single-quotes (‘) or delimiting the ampersand character with a backslash. The comments on this post all praise this solution.
Only problem… Neither worked for me. Then I thought, perhaps this is another “oddity” of running it on the Windows port. So, I tried enclosing the URL in double quotes and voila it worked! So, let that be a lesson to you: Don’t assume every ported program from Linux runs as you’d expect when under Windows.
Need to find all the Google Drive files that have been shared with someone? We can show you how to locate all these files/folders that have been specifically shared with someone from within the Google Drive web interface with no extra tools!