Skip to main content

Rename SQL user defined data type

Should we be using MsSQL user defined data types (UDDT)?

One advantage of using is that the same type can be standardized across similar fields across several tables. For example, we can have a UDDT defined for Email. However, the headache arrives when we need to alter the data type of the UDDT. There is no alter type yet to do the job.

What are the options to solving this problem? Do we really have to drop all objects (tables, stored procedures, etc) that use the UDDT, re-create the UDDT with the new type, and then re-create all tables, stored procedures, etc? That sounds quite a lot of work to do isn't it? What if we have existing records in tables and dropping tables sound way too risky.

Luckily, there is a workaround without dropping objects that use the UDDT (credit to a post on stackoverflow)

/* Create a new UDDT */
exec sp_addtype @typename='myUDT', @phystype='varchar(100)'
go

/* Create a table */
create table myTable (field1 myUdt)
go

/* Add a 'temporary' UDDT with the new definition */ 
exec sp_addtype @typename='tem_myUDT', @phystype='nvarchar(100)'
go

/*
1. Run below select statement
2. Copy the output result and run it
*/
select 'alter table dbo.' + TABLE_NAME + ' alter column ' + COLUMN_NAME + ' tem_myUDT' 
from INFORMATION_SCHEMA.COLUMNS 
where DOMAIN_NAME = 'myUDT'
go

/* Remove the old UDDT */ 
exec sp_droptype myUDT
go

/* Rename the 'temporary' UDDT to the correct name */ 
exec sp_rename 'tem_myUDT', 'myUDT', 'USERDATATYPE'
go

It works!

Popular Posts

Ho Ching named 5th most powerful and is mistaken as first lady by Forbes

Forbes named Singapore Prime Minister wife and CEO of Temasek Holdings, Ho Ching, as the 5th most powerful woman in the world. Ho Ching is mistaken as Singapore's first lady! OMG!

I wonder how can Forbes makes such a blunder. For a complete list, refer to here.

My opinion on PRUinvestor guaranteed plus product

I got to know of Prudential's new product PRUinvestor guaranteed plus only recently.

From agents, it is said to be 1) 100% Capital Guaranteed at maturity, 2) 2.5% p.a. interest guaranteed (Total 13.14%), 3) able to accept both cash and SRS, 4) and telling people application date for such "cool" product is ending soon but that's not really the case. I do not like the way products are marketed by agents.

1. 100% Capital Guaranteed at maturity

It is not really 100% guaranteed if it is guaranteed upon 36 months.

2. Sometimes marketed as 13.14%

This is a common tactic to "fool" aunties and uncles who are unaware of the compounding effect.

3. Able to accept SRS

At the rate of 2.5% p.a., I would say investing SRS monies in such product does not make sense to me since the new CPF interest rate structure is close to 2.5% p.a. too. At least CPF is truly 100% capital guaranteed.

4. Publish application date to be earlier than actual

This tactic attempts to make consumers make r…

How to stop FortiClient from starting automatically?

Installed FortiClient recently but the challenge in disabling the application/service from running automatically on every start-up annoyed me. Attempt to stop 'FortiClient Service Scheduler' only return 'Parameter is incorrect' error message.

An article on Technet help solve my trouble. To stop FortiClient from starting automatically, try the following:
Shut down FortiClient from the system tray.
Run net stop fortishield on command prompt.
Run msconfig.
On msconfig, switch to the Services tab. Clear the FortiClient Service Scheduler check box and click Apply.Run services.msc on command prompt to open up show all available services.Look for FortiClient Service Scheduler. Switch Startup type to Manual.Restart your computer. FortiClient should not be running automatically the next time round. Hope it helps.