Show current row “win streak” Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)Using Row_Number to find consecutive row countReset password for 'postgres' on v9.3 (Win Srv)Group by maximum consecutive rowMerging adjacent date intervals into a single rowTrigger function using current row and current table name as variablesTrigger function using current row and current table name as variables (final part)Selecting row grouped by an “add-on” indicatorFilter on time difference between current and next rowPostgreSQL: mark current session as “unimportant”How to count max date row if current status column is 0 or 2?

Does the Mueller report show a conspiracy between Russia and the Trump Campaign?

If Windows 7 doesn't support WSL, then what is "Subsystem for UNIX-based Applications"?

Positioning dot before text in math mode

What are the main differences between Stargate SG-1 cuts?

How can a team of shapeshifters communicate?

Does silver oxide react with hydrogen sulfide?

Delete free apps from library

Are the endpoints of the domain of a function counted as critical points?

How does light 'choose' between wave and particle behaviour?

What would you call this weird metallic apparatus that allows you to lift people?

How can I prevent/balance waiting and turtling as a response to cooldown mechanics

What initially awakened the Balrog?

Can two person see the same photon?

Google .dev domain strangely redirects to https

Is there public access to the Meteor Crater in Arizona?

What adaptations would allow standard fantasy dwarves to survive in the desert?

Why not send Voyager 3 and 4 following up the paths taken by Voyager 1 and 2 to re-transmit signals of later as they fly away from Earth?

What does it mean that physics no longer uses mechanical models to describe phenomena?

Did Mueller's report provide an evidentiary basis for the claim of Russian govt election interference via social media?

Why datecode is SO IMPORTANT to chip manufacturers?

What is the difference between CTSS and ITS?

Trying to understand entropy as a novice in thermodynamics

One-one communication

Co-worker has annoying ringtone



Show current row “win streak”



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)Using Row_Number to find consecutive row countReset password for 'postgres' on v9.3 (Win Srv)Group by maximum consecutive rowMerging adjacent date intervals into a single rowTrigger function using current row and current table name as variablesTrigger function using current row and current table name as variables (final part)Selecting row grouped by an “add-on” indicatorFilter on time difference between current and next rowPostgreSQL: mark current session as “unimportant”How to count max date row if current status column is 0 or 2?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








3















I need to show the running win/loss streak per row in a query, so given the table below, the query should return the "expected" column. I've tried some approaches with window functions, but no success.



create table matches (player text, dt date, is_winner boolean, expected integer )
insert into matches values
('A', '2019-01-01', TRUE, 0),
('A', '2019-01-03', TRUE, 1),
('A', '2019-01-04', TRUE, 2),
('A', '2019-01-09', FALSE, 0),
('A', '2019-01-10', FALSE, -1),
('A', '2019-01-15', TRUE, 0);


player dt is_winner expected
A 2019-01-01 true 0
A 2019-01-03 true 1
A 2019-01-04 true 2
A 2019-01-09 false 0
A 2019-01-10 false -1
A 2019-01-15 true 0



The logic is:



  1. Resets to 0 when winning after a loss, or losing after a win.

  2. Increments after a win, but not if it's case 1.

  3. Decrements after a loss, but not if it's case 1.

Any insights on how to tackle this are welcome. My last resort would be a function with a loop called by every row.










share|improve this question









New contributor




codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.


























    3















    I need to show the running win/loss streak per row in a query, so given the table below, the query should return the "expected" column. I've tried some approaches with window functions, but no success.



    create table matches (player text, dt date, is_winner boolean, expected integer )
    insert into matches values
    ('A', '2019-01-01', TRUE, 0),
    ('A', '2019-01-03', TRUE, 1),
    ('A', '2019-01-04', TRUE, 2),
    ('A', '2019-01-09', FALSE, 0),
    ('A', '2019-01-10', FALSE, -1),
    ('A', '2019-01-15', TRUE, 0);


    player dt is_winner expected
    A 2019-01-01 true 0
    A 2019-01-03 true 1
    A 2019-01-04 true 2
    A 2019-01-09 false 0
    A 2019-01-10 false -1
    A 2019-01-15 true 0



    The logic is:



    1. Resets to 0 when winning after a loss, or losing after a win.

    2. Increments after a win, but not if it's case 1.

    3. Decrements after a loss, but not if it's case 1.

    Any insights on how to tackle this are welcome. My last resort would be a function with a loop called by every row.










    share|improve this question









    New contributor




    codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.






















      3












      3








      3








      I need to show the running win/loss streak per row in a query, so given the table below, the query should return the "expected" column. I've tried some approaches with window functions, but no success.



      create table matches (player text, dt date, is_winner boolean, expected integer )
      insert into matches values
      ('A', '2019-01-01', TRUE, 0),
      ('A', '2019-01-03', TRUE, 1),
      ('A', '2019-01-04', TRUE, 2),
      ('A', '2019-01-09', FALSE, 0),
      ('A', '2019-01-10', FALSE, -1),
      ('A', '2019-01-15', TRUE, 0);


      player dt is_winner expected
      A 2019-01-01 true 0
      A 2019-01-03 true 1
      A 2019-01-04 true 2
      A 2019-01-09 false 0
      A 2019-01-10 false -1
      A 2019-01-15 true 0



      The logic is:



      1. Resets to 0 when winning after a loss, or losing after a win.

      2. Increments after a win, but not if it's case 1.

      3. Decrements after a loss, but not if it's case 1.

      Any insights on how to tackle this are welcome. My last resort would be a function with a loop called by every row.










      share|improve this question









      New contributor




      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.












      I need to show the running win/loss streak per row in a query, so given the table below, the query should return the "expected" column. I've tried some approaches with window functions, but no success.



      create table matches (player text, dt date, is_winner boolean, expected integer )
      insert into matches values
      ('A', '2019-01-01', TRUE, 0),
      ('A', '2019-01-03', TRUE, 1),
      ('A', '2019-01-04', TRUE, 2),
      ('A', '2019-01-09', FALSE, 0),
      ('A', '2019-01-10', FALSE, -1),
      ('A', '2019-01-15', TRUE, 0);


      player dt is_winner expected
      A 2019-01-01 true 0
      A 2019-01-03 true 1
      A 2019-01-04 true 2
      A 2019-01-09 false 0
      A 2019-01-10 false -1
      A 2019-01-15 true 0



      The logic is:



      1. Resets to 0 when winning after a loss, or losing after a win.

      2. Increments after a win, but not if it's case 1.

      3. Decrements after a loss, but not if it's case 1.

      Any insights on how to tackle this are welcome. My last resort would be a function with a loop called by every row.







      postgresql gaps-and-islands






      share|improve this question









      New contributor




      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited 3 hours ago









      Paul White

      54.3k14288461




      54.3k14288461






      New contributor




      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 10 hours ago









      codigofontescodigofontes

      183




      183




      New contributor




      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      codigofontes is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          1 Answer
          1






          active

          oldest

          votes


















          4














          I've done this in stages using CTEs so that you can see how it's done as the queries progress. Each CTE adds a column in the output in order to show you progress.



          It's pretty much self-documenting with the CTE names, to be honest.



          with lags as (
          select player,
          dt,
          is_winner,
          lag(is_winner) OVER (partition by player ORDER BY dt ASC) as prev_is_winner,
          expected
          from matches
          ),
          group_changes as (
          select lags.*,
          case
          when prev_is_winner <> is_winner or prev_is_winner is null
          then 1
          else 0
          end as is_new_group
          from lags
          ),
          groups_numbered as (
          select *,
          sum(is_new_group)
          over (partition by player order by dt, is_winner desc) as streak_group
          from group_changes
          ),
          expected_in_groups as (
          select groups_numbered.*,
          row_number()
          over (partition by player,streak_group
          order by dt asc, streak_group asc) - 1 as expected_unsigned
          from groups_numbered
          )
          select expected_in_groups.*, case when is_winner = 't' then expected_unsigned else expected_unsigned * -1 end as actual
          from expected_in_groups
          order by player asc, dt asc;


          DB Fiddle Link (I added an extra row just to make sure it was working at a certain point)



          Basically:




          1. lags CTE: use LAG() to get the previous result relative to the current row.


          2. group_changes CTE: Detect whether the previous streak, whether win or loss, has ended


          3. groups_numbered CTE: Give each streak a number


          4. expected_in_groups CTE: Number the rows in the group

          5. Final select: negate the loss streaks

          .



          +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
          | player | dt | is_winner | prev_is_winner | expected | is_new_group | streak_group | expected_unsigned | actual |
          +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
          | A | 2019-01-01 | t | | 0 | 1 | 1 | 0 | 0 |
          | A | 2019-01-03 | t | t | 1 | 0 | 1 | 1 | 1 |
          | A | 2019-01-04 | t | t | 2 | 0 | 1 | 2 | 2 |
          | A | 2019-01-09 | f | t | 0 | 1 | 2 | 0 | 0 |
          | A | 2019-01-10 | f | f | -1 | 0 | 2 | 1 | -1 |
          | A | 2019-01-11 | f | f | -2 | 0 | 2 | 2 | -2 |
          | A | 2019-01-15 | t | f | 0 | 1 | 3 | 0 | 0 |
          +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+





          share|improve this answer

























            Your Answer








            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "182"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: false,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );






            codigofontes is a new contributor. Be nice, and check out our Code of Conduct.









            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f235306%2fshow-current-row-win-streak%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            4














            I've done this in stages using CTEs so that you can see how it's done as the queries progress. Each CTE adds a column in the output in order to show you progress.



            It's pretty much self-documenting with the CTE names, to be honest.



            with lags as (
            select player,
            dt,
            is_winner,
            lag(is_winner) OVER (partition by player ORDER BY dt ASC) as prev_is_winner,
            expected
            from matches
            ),
            group_changes as (
            select lags.*,
            case
            when prev_is_winner <> is_winner or prev_is_winner is null
            then 1
            else 0
            end as is_new_group
            from lags
            ),
            groups_numbered as (
            select *,
            sum(is_new_group)
            over (partition by player order by dt, is_winner desc) as streak_group
            from group_changes
            ),
            expected_in_groups as (
            select groups_numbered.*,
            row_number()
            over (partition by player,streak_group
            order by dt asc, streak_group asc) - 1 as expected_unsigned
            from groups_numbered
            )
            select expected_in_groups.*, case when is_winner = 't' then expected_unsigned else expected_unsigned * -1 end as actual
            from expected_in_groups
            order by player asc, dt asc;


            DB Fiddle Link (I added an extra row just to make sure it was working at a certain point)



            Basically:




            1. lags CTE: use LAG() to get the previous result relative to the current row.


            2. group_changes CTE: Detect whether the previous streak, whether win or loss, has ended


            3. groups_numbered CTE: Give each streak a number


            4. expected_in_groups CTE: Number the rows in the group

            5. Final select: negate the loss streaks

            .



            +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
            | player | dt | is_winner | prev_is_winner | expected | is_new_group | streak_group | expected_unsigned | actual |
            +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
            | A | 2019-01-01 | t | | 0 | 1 | 1 | 0 | 0 |
            | A | 2019-01-03 | t | t | 1 | 0 | 1 | 1 | 1 |
            | A | 2019-01-04 | t | t | 2 | 0 | 1 | 2 | 2 |
            | A | 2019-01-09 | f | t | 0 | 1 | 2 | 0 | 0 |
            | A | 2019-01-10 | f | f | -1 | 0 | 2 | 1 | -1 |
            | A | 2019-01-11 | f | f | -2 | 0 | 2 | 2 | -2 |
            | A | 2019-01-15 | t | f | 0 | 1 | 3 | 0 | 0 |
            +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+





            share|improve this answer





























              4














              I've done this in stages using CTEs so that you can see how it's done as the queries progress. Each CTE adds a column in the output in order to show you progress.



              It's pretty much self-documenting with the CTE names, to be honest.



              with lags as (
              select player,
              dt,
              is_winner,
              lag(is_winner) OVER (partition by player ORDER BY dt ASC) as prev_is_winner,
              expected
              from matches
              ),
              group_changes as (
              select lags.*,
              case
              when prev_is_winner <> is_winner or prev_is_winner is null
              then 1
              else 0
              end as is_new_group
              from lags
              ),
              groups_numbered as (
              select *,
              sum(is_new_group)
              over (partition by player order by dt, is_winner desc) as streak_group
              from group_changes
              ),
              expected_in_groups as (
              select groups_numbered.*,
              row_number()
              over (partition by player,streak_group
              order by dt asc, streak_group asc) - 1 as expected_unsigned
              from groups_numbered
              )
              select expected_in_groups.*, case when is_winner = 't' then expected_unsigned else expected_unsigned * -1 end as actual
              from expected_in_groups
              order by player asc, dt asc;


              DB Fiddle Link (I added an extra row just to make sure it was working at a certain point)



              Basically:




              1. lags CTE: use LAG() to get the previous result relative to the current row.


              2. group_changes CTE: Detect whether the previous streak, whether win or loss, has ended


              3. groups_numbered CTE: Give each streak a number


              4. expected_in_groups CTE: Number the rows in the group

              5. Final select: negate the loss streaks

              .



              +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
              | player | dt | is_winner | prev_is_winner | expected | is_new_group | streak_group | expected_unsigned | actual |
              +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
              | A | 2019-01-01 | t | | 0 | 1 | 1 | 0 | 0 |
              | A | 2019-01-03 | t | t | 1 | 0 | 1 | 1 | 1 |
              | A | 2019-01-04 | t | t | 2 | 0 | 1 | 2 | 2 |
              | A | 2019-01-09 | f | t | 0 | 1 | 2 | 0 | 0 |
              | A | 2019-01-10 | f | f | -1 | 0 | 2 | 1 | -1 |
              | A | 2019-01-11 | f | f | -2 | 0 | 2 | 2 | -2 |
              | A | 2019-01-15 | t | f | 0 | 1 | 3 | 0 | 0 |
              +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+





              share|improve this answer



























                4












                4








                4







                I've done this in stages using CTEs so that you can see how it's done as the queries progress. Each CTE adds a column in the output in order to show you progress.



                It's pretty much self-documenting with the CTE names, to be honest.



                with lags as (
                select player,
                dt,
                is_winner,
                lag(is_winner) OVER (partition by player ORDER BY dt ASC) as prev_is_winner,
                expected
                from matches
                ),
                group_changes as (
                select lags.*,
                case
                when prev_is_winner <> is_winner or prev_is_winner is null
                then 1
                else 0
                end as is_new_group
                from lags
                ),
                groups_numbered as (
                select *,
                sum(is_new_group)
                over (partition by player order by dt, is_winner desc) as streak_group
                from group_changes
                ),
                expected_in_groups as (
                select groups_numbered.*,
                row_number()
                over (partition by player,streak_group
                order by dt asc, streak_group asc) - 1 as expected_unsigned
                from groups_numbered
                )
                select expected_in_groups.*, case when is_winner = 't' then expected_unsigned else expected_unsigned * -1 end as actual
                from expected_in_groups
                order by player asc, dt asc;


                DB Fiddle Link (I added an extra row just to make sure it was working at a certain point)



                Basically:




                1. lags CTE: use LAG() to get the previous result relative to the current row.


                2. group_changes CTE: Detect whether the previous streak, whether win or loss, has ended


                3. groups_numbered CTE: Give each streak a number


                4. expected_in_groups CTE: Number the rows in the group

                5. Final select: negate the loss streaks

                .



                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
                | player | dt | is_winner | prev_is_winner | expected | is_new_group | streak_group | expected_unsigned | actual |
                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
                | A | 2019-01-01 | t | | 0 | 1 | 1 | 0 | 0 |
                | A | 2019-01-03 | t | t | 1 | 0 | 1 | 1 | 1 |
                | A | 2019-01-04 | t | t | 2 | 0 | 1 | 2 | 2 |
                | A | 2019-01-09 | f | t | 0 | 1 | 2 | 0 | 0 |
                | A | 2019-01-10 | f | f | -1 | 0 | 2 | 1 | -1 |
                | A | 2019-01-11 | f | f | -2 | 0 | 2 | 2 | -2 |
                | A | 2019-01-15 | t | f | 0 | 1 | 3 | 0 | 0 |
                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+





                share|improve this answer















                I've done this in stages using CTEs so that you can see how it's done as the queries progress. Each CTE adds a column in the output in order to show you progress.



                It's pretty much self-documenting with the CTE names, to be honest.



                with lags as (
                select player,
                dt,
                is_winner,
                lag(is_winner) OVER (partition by player ORDER BY dt ASC) as prev_is_winner,
                expected
                from matches
                ),
                group_changes as (
                select lags.*,
                case
                when prev_is_winner <> is_winner or prev_is_winner is null
                then 1
                else 0
                end as is_new_group
                from lags
                ),
                groups_numbered as (
                select *,
                sum(is_new_group)
                over (partition by player order by dt, is_winner desc) as streak_group
                from group_changes
                ),
                expected_in_groups as (
                select groups_numbered.*,
                row_number()
                over (partition by player,streak_group
                order by dt asc, streak_group asc) - 1 as expected_unsigned
                from groups_numbered
                )
                select expected_in_groups.*, case when is_winner = 't' then expected_unsigned else expected_unsigned * -1 end as actual
                from expected_in_groups
                order by player asc, dt asc;


                DB Fiddle Link (I added an extra row just to make sure it was working at a certain point)



                Basically:




                1. lags CTE: use LAG() to get the previous result relative to the current row.


                2. group_changes CTE: Detect whether the previous streak, whether win or loss, has ended


                3. groups_numbered CTE: Give each streak a number


                4. expected_in_groups CTE: Number the rows in the group

                5. Final select: negate the loss streaks

                .



                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
                | player | dt | is_winner | prev_is_winner | expected | is_new_group | streak_group | expected_unsigned | actual |
                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+
                | A | 2019-01-01 | t | | 0 | 1 | 1 | 0 | 0 |
                | A | 2019-01-03 | t | t | 1 | 0 | 1 | 1 | 1 |
                | A | 2019-01-04 | t | t | 2 | 0 | 1 | 2 | 2 |
                | A | 2019-01-09 | f | t | 0 | 1 | 2 | 0 | 0 |
                | A | 2019-01-10 | f | f | -1 | 0 | 2 | 1 | -1 |
                | A | 2019-01-11 | f | f | -2 | 0 | 2 | 2 | -2 |
                | A | 2019-01-15 | t | f | 0 | 1 | 3 | 0 | 0 |
                +--------+------------+-----------+----------------+----------+--------------+--------------+-------------------+--------+






                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited 8 hours ago

























                answered 8 hours ago









                PhilᵀᴹPhilᵀᴹ

                25.9k65691




                25.9k65691




















                    codigofontes is a new contributor. Be nice, and check out our Code of Conduct.









                    draft saved

                    draft discarded


















                    codigofontes is a new contributor. Be nice, and check out our Code of Conduct.












                    codigofontes is a new contributor. Be nice, and check out our Code of Conduct.











                    codigofontes is a new contributor. Be nice, and check out our Code of Conduct.














                    Thanks for contributing an answer to Database Administrators Stack Exchange!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f235306%2fshow-current-row-win-streak%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    На ростанях Змест Гісторыя напісання | Месца дзеяння | Час дзеяння | Назва | Праблематыка трылогіі | Аўтабіяграфічнасць | Трылогія ў тэатры і кіно | Пераклады | У культуры | Зноскі Літаратура | Спасылкі | НавігацыяДагледжаная версіяправерана1 зменаДагледжаная версіяправерана1 зменаАкадэмік МІЦКЕВІЧ Канстанцін Міхайлавіч (Якуб Колас) Прадмова М. І. Мушынскага, доктара філалагічных навук, члена-карэспандэнта Нацыянальнай акадэміі навук Рэспублікі Беларусь, прафесараНашаніўцы ў трылогіі Якуба Коласа «На ростанях»: вобразы і прататыпы125 лет Янке МавруКнижно-документальная выставка к 125-летию со дня рождения Якуба Коласа (1882—1956)Колас Якуб. Новая зямля (паэма), На ростанях (трылогія). Сулкоўскі Уладзімір. Радзіма Якуба Коласа (серыял жывапісных палотнаў)Вокладка кнігіІлюстрацыя М. С. БасалыгіНа ростаняхАўдыёверсія трылогііВ. Жолтак У Люсiнскай школе 1959

                    Францішак Багушэвіч Змест Сям'я | Біяграфія | Творчасць | Мова Багушэвіча | Ацэнкі дзейнасці | Цікавыя факты | Спадчына | Выбраная бібліяграфія | Ушанаванне памяці | У філатэліі | Зноскі | Літаратура | Спасылкі | НавігацыяЛяхоўскі У. Рупіўся дзеля Бога і людзей: Жыццёвы шлях Лявона Вітан-Дубейкаўскага // Вольскі і Памідораў з песняй пра немца Адвакат, паэт, народны заступнік Ашмянскі веснікВ Минске появится площадь Богушевича и улица Сырокомли, Белорусская деловая газета, 19 июля 2001 г.Айцец беларускай нацыянальнай ідэі паўстаў у бронзе Сяргей Аляксандравіч Адашкевіч (1918, Мінск). 80-я гады. Бюст «Францішак Багушэвіч».Яўген Мікалаевіч Ціхановіч. «Партрэт Францішка Багушэвіча»Мікола Мікалаевіч Купава. «Партрэт зачынальніка новай беларускай літаратуры Францішка Багушэвіча»Уладзімір Іванавіч Мелехаў. На помніку «Змагарам за родную мову» Барэльеф «Францішак Багушэвіч»Памяць пра Багушэвіча на Віленшчыне Страчаная сталіца. Беларускія шыльды на вуліцах Вільні«Krynica». Ideologia i przywódcy białoruskiego katolicyzmuФранцішак БагушэвічТворы на knihi.comТворы Францішка Багушэвіча на bellib.byСодаль Уладзімір. Францішак Багушэвіч на Лідчыне;Луцкевіч Антон. Жыцьцё і творчасьць Фр. Багушэвіча ў успамінах ягоных сучасьнікаў // Запісы Беларускага Навуковага таварыства. Вільня, 1938. Сшытак 1. С. 16-34.Большая российская1188761710000 0000 5537 633Xn9209310021619551927869394п

                    Беларусь Змест Назва Гісторыя Геаграфія Сімволіка Дзяржаўны лад Палітычныя партыі Міжнароднае становішча і знешняя палітыка Адміністрацыйны падзел Насельніцтва Эканоміка Культура і грамадства Сацыяльная сфера Узброеныя сілы Заўвагі Літаратура Спасылкі НавігацыяHGЯOiТоп-2011 г. (па версіі ej.by)Топ-2013 г. (па версіі ej.by)Топ-2016 г. (па версіі ej.by)Топ-2017 г. (па версіі ej.by)Нацыянальны статыстычны камітэт Рэспублікі БеларусьШчыльнасць насельніцтва па краінахhttp://naviny.by/rubrics/society/2011/09/16/ic_articles_116_175144/А. Калечыц, У. Ксяндзоў. Спробы засялення краю неандэртальскім чалавекам.І ў Менску былі мамантыА. Калечыц, У. Ксяндзоў. Старажытны каменны век (палеаліт). Першапачатковае засяленне тэрыторыіГ. Штыхаў. Балты і славяне ў VI—VIII стст.М. Клімаў. Полацкае княства ў IX—XI стст.Г. Штыхаў, В. Ляўко. Палітычная гісторыя Полацкай зямліГ. Штыхаў. Дзяржаўны лад у землях-княствахГ. Штыхаў. Дзяржаўны лад у землях-княствахБеларускія землі ў складзе Вялікага Княства ЛітоўскагаЛюблінская унія 1569 г."The Early Stages of Independence"Zapomniane prawdy25 гадоў таму было аб'яўлена, што Язэп Пілсудскі — беларус (фота)Наша вадаДакументы ЧАЭС: Забруджванне тэрыторыі Беларусі « ЧАЭС Зона адчужэнняСведения о политических партиях, зарегистрированных в Республике Беларусь // Министерство юстиции Республики БеларусьСтатыстычны бюлетэнь „Полаўзроставая структура насельніцтва Рэспублікі Беларусь на 1 студзеня 2012 года і сярэднегадовая колькасць насельніцтва за 2011 год“Индекс человеческого развития Беларуси — не было бы нижеБеларусь занимает первое место в СНГ по индексу развития с учетом гендерного факцёраНацыянальны статыстычны камітэт Рэспублікі БеларусьКанстытуцыя РБ. Артыкул 17Трансфармацыйныя задачы БеларусіВыйсце з крызісу — далейшае рэфармаванне Беларускі рубель — сусветны лідар па дэвальвацыяхПра змену коштаў у кастрычніку 2011 г.Бядней за беларусаў у СНД толькі таджыкіСярэдні заробак у верасні дасягнуў 2,26 мільёна рублёўЭканомікаГаласуем за ТОП-100 беларускай прозыСучасныя беларускія мастакіАрхитектура Беларуси BELARUS.BYА. Каханоўскі. Культура Беларусі ўсярэдзіне XVII—XVIII ст.Анталогія беларускай народнай песні, гуказапісы спеваўБеларускія Музычныя IнструментыБеларускі рок, які мы страцілі. Топ-10 гуртоў«Мясцовы час» — нязгаслая легенда беларускай рок-музыкіСЯРГЕЙ БУДКІН. МЫ НЯ ЗНАЕМ СВАЁЙ МУЗЫКІМ. А. Каладзінскі. НАРОДНЫ ТЭАТРМагнацкія культурныя цэнтрыПублічная дыскусія «Беларуская новая пьеса: без беларускай мовы ці беларуская?»Беларускія драматургі па-ранейшаму лепш ставяцца за мяжой, чым на радзіме«Працэс незалежнага кіно пайшоў, і дзяржаву турбуе яго непадкантрольнасць»Беларускія філосафы ў пошуках прасторыВсе идём в библиотекуАрхіваванаАб Нацыянальнай праграме даследавання і выкарыстання касмічнай прасторы ў мірных мэтах на 2008—2012 гадыУ космас — разам.У суседнім з Барысаўскім раёне пабудуюць Камандна-вымяральны пунктСвяты і абрады беларусаў«Мірныя бульбашы з малой краіны» — 5 непраўдзівых стэрэатыпаў пра БеларусьМ. Раманюк. Беларускае народнае адзеннеУ Беларусі скарачаецца колькасць злачынстваўЛукашэнка незадаволены мінскімі ўладамі Крадзяжы складаюць у Мінску каля 70% злачынстваў Узровень злачыннасці ў Мінскай вобласці — адзін з самых высокіх у краіне Генпракуратура аналізуе стан са злачыннасцю ў Беларусі па каэфіцыенце злачыннасці У Беларусі стабілізавалася крымінагеннае становішча, лічыць генпракурорЗамежнікі сталі здзяйсняць у Беларусі больш злачынстваўМУС Беларусі турбуе рост рэцыдыўнай злачыннасціЯ з ЖЭСа. Дазволіце вас абкрасці! Рэйтынг усіх службаў і падраздзяленняў ГУУС Мінгарвыканкама вырасАб КДБ РБГісторыя Аператыўна-аналітычнага цэнтра РБГісторыя ДКФРТаможняagentura.ruБеларусьBelarus.by — Афіцыйны сайт Рэспублікі БеларусьСайт урада БеларусіRadzima.org — Збор архітэктурных помнікаў, гісторыя Беларусі«Глобус Беларуси»Гербы и флаги БеларусиАсаблівасці каменнага веку на БеларусіА. Калечыц, У. Ксяндзоў. Старажытны каменны век (палеаліт). Першапачатковае засяленне тэрыторыіУ. Ксяндзоў. Сярэдні каменны век (мезаліт). Засяленне краю плямёнамі паляўнічых, рыбакоў і збіральнікаўА. Калечыц, М. Чарняўскі. Плямёны на тэрыторыі Беларусі ў новым каменным веку (неаліце)А. Калечыц, У. Ксяндзоў, М. Чарняўскі. Гаспадарчыя заняткі ў каменным векуЭ. Зайкоўскі. Духоўная культура ў каменным векуАсаблівасці бронзавага веку на БеларусіФарміраванне супольнасцей ранняга перыяду бронзавага векуФотографии БеларусиРоля беларускіх зямель ва ўтварэнні і ўмацаванні ВКЛВ. Фадзеева. З гісторыі развіцця беларускай народнай вышыўкіDMOZGran catalanaБольшая российскаяBritannica (анлайн)Швейцарскі гістарычны15325917611952699xDA123282154079143-90000 0001 2171 2080n9112870100577502ge128882171858027501086026362074122714179пппппп