Mediaani

MySQL

Miten keskiarvon sijasta saisi Mediaanin MySQL:ssa?

3

1587

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • I.Proqatlis
      • I.Proqatlis

      • I.Proqatlis
        I.Proqatlis kirjoitti:

        Tässä on ehkä helpommin tajuttavaa tekstiä:

        http://www.rocket99.com/techref/8686.html

        Googleta "median sql" niin saat koko joukon sivuja, joista voit löytää apua.

        Olin viitseliäs ja kehitin oman MySQL-versioni ylläolevassa viestissäni mainitun saitin algoritmista.

        Idea on seuraava. Luodaan tietokantaan proseduuri, joka laskee annetun joukon mediaaniarvon.

        1. Käytetään aputauluja tyotaulu ja mediaani. Vanhat mahdollisesti olemassaolevat taulut poistetaan tietoineen kannasta ja uudet luodaan tilalle.

        2. Työtaulu populoidaan sillä joukolla, jonka mediaaniarvo halutaan laskea. Tässä kysyjän pitää käyttää omaa tietokantaansa. Esimerkissäni minulla on tietokanta nimeltä jalkapallo. Se sisältää mm. taulun nimeltä tilanteet, ja tässä taulussa on kenttä tehdytMaalit. On huomattava, että arvot tulee insertoida suuruusjärjestyksessä.

        3. Tämän jälkeen selvitetään, montako riviä työtaulussa on.

        4. Mediaani siis on suuruusjärjestyksessä olevan joukon keskimmäinen luku, jos alkioita on pariton määrä. Jos taas määrä on parillinen luku, mediaani on kahden keskimmäisen keskiarvo.

        floor(riviMaara / 2) palauttaa suurimman kokonaisluvun, joka on enintään (riviMaara / 2):n suuruinen.

        Jos rivimaara on 15, tulos on siis 7. Jos rivimaara on 16, tulos on 8.

        5. Muuttuja keskiPiste saa arvon hieman eri tavoin riippuen siitä, onko alkiomäärä parillinen vai pariton. Menettely käynee koodista selville. Sitten otetaan suurin keskipisteestä vasemmalle oleva alkio sekä pienin keskipisteestä oikealle oleva alkio ja lasketaan näiden keskiarvo.

        6. Edellisessä kohdassa saatu arvo talletetaan mediaani-tauluun, josta se voidaan lukea. Vaihtoehtoinen tapa olisi palauttaa arvo output-muuttujassa. Kysyjä voi valita haluamansa tavan.

        Seuraava create procedure -operaatio luo tietokantaan proseduurin LaskeMediaani. Sen jälkeen sitä voidaan kutsua esim. kirjoittamalla MySQL Query Browserin ikkunassa

        call LaskeMediaani();

        Tämä toimii MySQL 5 -versiossa ja olen sen siinä myös testannut. Jos jotain jäi hämäräksi, niin vastaan mahdollisesti esille nouseviin kysymyksiin! Kysyjän pitää muokata muuttujat itselleen sopiviksi, jos hän haluaa laskea desimaalilukuja sisältävän joukon mediaanin. Esimerkissäni esiintyy vain kokonaislukuja.

        ---------------------------------------------------------------------------------------------------

        DELIMITER $$

        DROP PROCEDURE IF EXISTS `jalkapallo`.`LaskeMediaani` $$
        CREATE PROCEDURE `jalkapallo`.`LaskeMediaani` ()
        BEGIN

        declare riviMaara integer unsigned;
        declare vasenArvo integer unsigned;
        declare oikeaArvo integer unsigned;
        declare jakoJaannos integer unsigned;

        declare keskiPiste decimal(6, 1);
        declare mediaaniArvo decimal(6, 1);

        drop table if exists tyotaulu;
        drop table if exists mediaani;

        create table tyotaulu (
        jnro integer unsigned not null auto_increment,
        arvo integer unsigned not null,
        primary key (jnro)
        );

        create table mediaani (
        arvo decimal(4, 1)
        );

        insert into tyotaulu (arvo)
        select tehdytMaalit from tilanteet order by tehdytMaalit;

        set riviMaara = ( select count(*) from tyotaulu ) ;
        set keskiPiste = ( select floor(riviMaara / 2 ));
        set jakoJaannos = ( select mod(riviMaara, 2 ));

        if jakoJaannos > 0 then
        set keskiPiste = keskiPiste 1;
        else
        set keskiPiste = keskiPiste 0.1;
        end if;

        set vasenArvo = (select max(arvo) from tyotaulu where jnro = keskiPiste);

        set mediaaniArvo = (vasenArvo oikeaArvo) / 2;

        insert into mediaani (arvo) values (mediaaniArvo);

        END $$

        DELIMITER ;







           


    Ketjusta on poistettu 1 sääntöjenvastaista viestiä.

    Takaisin ylös

    Luetuimmat keskustelut

    1. Milloin viimeksi näit ikäväsi kohteen?

      Oliko helppo tunnistaa hänet? Millaisia tunteita tuo näkeminen herätti sinussa?
      Ikävä
      69
      1305
    2. En tiedä..

      Yhtään minkälainen miesmaku sinulla on. itse arvioin sinua moneenkin otteeseen ja joka kerta päädyin samaan lopputulokse
      Ikävä
      106
      1217
    3. Suhde asiaa

      Miksi et halua suhdetta kanssani?
      Ikävä
      113
      1155
    4. Kirjoita nainen meistä jotain tänne

      tai minusta, ihan mitä haluat. Niinkin voi kirjoittaa, etteivät muut tunnista, esim. meidän kahdenkeskisistä jutuista. K
      Ikävä
      73
      1070
    5. Paras olisi vain unohtaa

      Tuleekohan tähän meidän tilanteeseen ikinä mitään selvyyttä. Epätoivo iskee taas, enkä jaksaisi enää odottaa. Kohta lop
      Ikävä
      56
      861
    6. IS viikonloppu 18-19.5.2024.

      Laatija Toni Pitkälä on itse laatinut ja kuvittanut 3- arvoista ristikkonsa. Nihkeästi tuntuu löytyvän ensimmäisiä var
      Sanaristikot
      75
      751
    7. Oliko vähä sometettu taas vai?

      Tuli aiva liika nopiaa traktorin perä vastahan. https://www.iltalehti.fi/kotimaa/a/2b3857b3-f2c6-424e-8051-506c7525223a
      Kauhava
      9
      682
    8. Voisitko laittaa

      Nimesi ensimmäisen ja kaksi viimeistä kirjainta tähän?
      Ikävä
      41
      681
    9. Kristityn megahyökkäys idän palstoilla on kauhistuttava

      Terroristikristityn megahyökkäys joka puolella on kauhistuttava, hänen viesteissään on järjetön määrä vihaa. Hän on idän
      Idän uskonnot
      362
      669
    10. S on minun etunimen kolmas kirjain.

      Mikä sinun etunimen kolmas kirjain on?
      Ikävä
      53
      646
    Aihe