Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Ändra Collation

Postades av 2009-11-15 18:24:18 - Claes Andskär, i forum sql-server/msde, Tråden har 1 Kommentarer och lästs av 1695 personer

Hej

Går det skriva ett script som ändrar collation på alla kolumner i alla tabeller i en databas?
Eller är det bara bita ihop och sätta igång för hand?

Hur påverkas index av att man gör detta?

mvh
Claes Andskär


Svara

Sv: Ändra Collation

Postades av 2009-11-16 10:33:50 - Håkan Borneland

Hej!
Hittade det här (otestat) på MSDN forumet för Transact SQL.
Pröva på en kopia (skapa en av en backup, t.ex) först.
<code>
DECLARE @new_collation varchar(128)

, @cmd_holder varchar(2000)

, @cmd_complete varchar(2000)

, @schema varchar(128)

, @table_name varchar(128)

, @column_name varchar(128)

, @data_type varchar(128)

, @length varchar(4)

, @nullability varchar(8)

SET @new_collation = 'latin1_general_cs_as'

SET @cmd_holder = '

ALTER TABLE $schema.$table_name

ALTER COLUMN $column_name $data_type($length) COLLATE $new_collation $nullability

'

DECLARE column_cursor CURSOR FOR

SELECT table_schema

, table_name

, column_name

, data_type

, CASE WHEN character_maximum_length = -1 THEN 'max' ELSE Convert(varchar(4), character_maximum_length) END As length

, CASE WHEN is_nullable = 'YES' THEN 'NULL' ELSE 'NOT NULL' END As nullability

FROM information_schema.columns

WHERE data_type IN ('char', 'varchar')

OPEN column_cursor

FETCH NEXT FROM column_cursor

INTO @schema, @table_name, @column_name, @data_type, @length, @nullability

WHILE @@Fetch_Status = 0

BEGIN

SELECT @cmd_complete = @cmd_holder

, @cmd_complete = Replace(@cmd_complete, '$schema' , @schema)

, @cmd_complete = Replace(@cmd_complete, '$table_name' , @table_name)

, @cmd_complete = Replace(@cmd_complete, '$column_name' , @column_name)

, @cmd_complete = Replace(@cmd_complete, '$data_type' , @data_type)

, @cmd_complete = Replace(@cmd_complete, '$length' , @length)

, @cmd_complete = Replace(@cmd_complete, '$new_collation', @new_collation)

, @cmd_complete = Replace(@cmd_complete, '$nullability' , @nullability)

PRINT @cmd_complete

--EXEC @cmd

FETCH NEXT FROM column_cursor

INTO @schema, @table_name, @column_name, @data_type, @length, @nullability

END

CLOSE column_cursor

DEALLOCATE column_cursor
</code>


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 616
27 953
271 709
5 587
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies