SQL Serveri ülekandefunktsioon

Sql Serveri Ulekandefunktsioon



„Ükskõik, kas olete alles alustamas või kogenud arendaja, puutute kokku tüübikonversiooniga. Tüübi teisendamine viitab väärtuse või avaldise teisendamisele ühest andmetüübist teise ühilduvasse andmetüüpi.

Selles postituses käsitleme SQL Serveri funktsiooni cast() kasutamist väärtuse või avaldise teisendamiseks ühest tüübist teise.







SQL Serveri ülekandefunktsioon

Järgmine väljavõte näitab funktsiooni cast() süntaksit.



CAST ( väljendus AS andmetüüp [ ( PIKKUS ) ] )

Funktsioon aktsepteerib järgmisi parameetreid:



  1. väljend – mis tahes kehtiv avaldis.
  2. data_type – määrab sihtandmete tüübi.
  3. pikkus – valikuline täisarv, mis on määratletud sihtandmetüübi pikkusena (ainult toetatud tüüpide puhul).

Funktsioon tagastab seejärel avaldise, mis on teisendatud sihtandmete_tüübiks.





Kasutame näiteid, et illustreerida, kuidas cast-funktsiooni kasutada.

Cast-funktsiooni kasutamine stringi täisarvuks teisendamiseks

Järgmises näites kasutatakse cast-funktsiooni sisendstringi täisarvuks teisendamiseks.



VALI
CAST ( '100' AS INT ) AS väljundi_väärtus;

Saadud väljund:

väljundi_väärtus |
------------+
100 |

Cast-funktsiooni kasutamine kümnendkoha teisendamiseks Int

Teises allolevas näites kasutatakse cast-funktsiooni kümnendkoha tüübi teisendamiseks int-ks.

VALI
CAST ( 3,14159 AS INT ) AS väljundi_väärtus;

Ülekandefunktsioon ümardab sisendi kümnendkoha lähima täisarvuni, nagu näidatud:

väljundi_väärtus |
------------+
3 |

Cast-funktsiooni kasutamine stringi teisendamiseks kuupäeva-kellaajaks

Võime kasutada ka ülekandefunktsiooni, et teisendada antud sisendstring kuupäeva ja kellaaja väärtuseks. Illustratsiooni näide on näidatud allpool:

VALI
CAST ( '2022-10-10' AS kuupäev Kellaaeg ) AS väljundi_väärtus;

Tulemuseks olev väljund:

väljundi_väärtus |
-----------------------+
2022. aasta - 10 - 10 00:00: 00 000 |

Ülekandmisfunktsiooni kasutamine tabeli veerus

Samuti saame cast-funktsiooni rakendada konkreetsele veerule ja teisendada selle veeru read teise andmetüübi alla.

Oletame näiteks, et meil on tabel:

Saame teisendada veeru size_on_disk väärtused täisarvudeks, nagu näidatud:

VALI
serveri_nimi ,
CAST ( suurus_kettal AS INT ) AS appx_size
FROM
sissekanded;

Saadud tabel on järgmine:

Nagu näeme, väljendatakse saadud väljundit täisarvudena (ümardatud).

MÄRKUS. Hea on meeles pidada, et konversioonitüüpe on erinevaid.

  1. Kaudne teisendamine – SQL Serveri mootor rakendab automaatselt teisendustoimingu, et see vastaks kõige paremini soovitud toimingule.
  2. Selgesõnaline teisendamine – kasutaja teeb selle käsitsi, kutsudes välja teisendusfunktsioone, nagu cast() ja convert().

Järgmine diagramm näitab, milliseid tüüpe saate teisendada, millist tüüpi konversiooni rakendatakse ja palju muud.

Allikas: Microsoft

Nullimine

Täname, et lugesite seda õpetust. Usume, et õppisite sellest juhendist midagi uut.