sql >> Database teknologi >  >> RDS >> Sqlserver

Opdatering Samling af alle felter i databasen på farten

Bare hvis nogen, der ser på dette, bruger SQL Server 2008, var jeg nødt til at foretage et par ændringer:

SELECT 'ALTER TABLE [' + sys.objects.name + '] ALTER COLUMN ['
+ sys.columns.name + '] ' + sys.types.name + 
    CASE sys.types.name
    WHEN 'text' THEN ' '
    ELSE
    '(' + RTRIM(CASE sys.columns.max_length
    WHEN -1 THEN 'MAX'
    ELSE CONVERT(CHAR,sys.columns.max_length)
    END) + ') ' 
    END

    + ' ' + ' COLLATE Latin1_General_BIN ' + CASE sys.columns.is_nullable WHEN 0 THEN 'NOT NULL' ELSE 'NULL' END
    FROM sys.columns , sys.objects , sys.types
    WHERE sys.columns.object_id = sys.objects.object_id
    AND sys.objects.TYPE = 'U'
    AND sys.types.system_type_id = sys.columns.system_type_id
    AND sys.columns.collation_name IS NOT NULL
    AND NOT ( sys.objects.NAME LIKE 'sys%' )
    AND NOT ( sys.types.name LIKE 'sys%' )


  1. REGEXP_REPLACE() Funktion i Oracle

  2. Sørg for, at områdeværdien ikke overlapper med eksisterende områder

  3. sql-forespørgsel med if-statment

  4. Indsæt data i mysql colum med mellemrum med php