Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
131 views
in Technique[技术] by (71.8m points)

How to create a stored procedure in SQL Server that can determine the best data types for all the columns in a table?


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Not a fun place to be and I have been there myself. Depending on your version of SQL SERVER (TRY_PARSE requires min 2012), you could try something like this:

DECLARE @UntypedData table ( nvarchar_value nvarchar(255), id int IDENTITY (1,1) );
INSERT INTO @UntypedData VALUES
    ( '1000' ), ( '1000.00' ), ( '12/31/2020' ), ( '2020-12-31 11:59:23' );

SELECT
    nvarchar_value,
    CASE
        WHEN CHARINDEX( '.', nvarchar_value ) > 0 AND TRY_PARSE( nvarchar_value AS decimal ) IS NOT NULL THEN 'decimal'
        WHEN TRY_PARSE( nvarchar_value AS int ) IS NOT NULL THEN 'int'
        WHEN CHARINDEX( ':', nvarchar_value ) > 0 AND TRY_PARSE( nvarchar_value AS datetime ) IS NOT NULL THEN 'datetime'
        WHEN TRY_PARSE( nvarchar_value AS date ) IS NOT NULL THEN 'date'
        ELSE 'string'
    END AS suspected_data_type
FROM @UntypedData ORDER BY id;

Returns

+---------------------+---------------------+
|   nvarchar_value    | suspected_data_type |
+---------------------+---------------------+
| 1000                | int                 |
| 1000.00             | decimal             |
| 12/31/2020          | date                |
| 2020-12-31 11:59:23 | datetime            |
+---------------------+---------------------+

This is just an idea to check for datatypes as there's so much you need to consider with a task like this ( string length, decimal size, etc ). For starters though, do not limit your type detection to a single row. I personally would test all rows before changing their datatype--or at least enough to be confident.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...