| |

VerySource

 Forgot password?
 Register
Search
View: 871|Reply: 6

Consult a mysql data concurrency, causing inaccurate data statistics, very urgent !!!!!!!!!!!!!!!!!!!!!!!!!!!!!

[Copy link]

1

Threads

5

Posts

6.00

Credits

Newbie

Rank: 1

Credits
6.00

 China

Post time: 2020-1-4 18:10:01
| Show all posts |Read mode
Consult a mysql data concurrency, causing inaccurate data statistics, urgent
I used jsp + mysql to make a website statistics. After inserting statistics code into your website, I counted your total browsing IP data, and the total number of browsing IPs per day, and the total number of browsing IPs per hour per day.

But after I found the statistics, the numbers added per hour, I am sorry for the daily data, the data added for each day, not the total number of browsing IPs, I use the mysql database, and I use the mysql MyISAM format.

My program code is as follows:


Is it that mysql has a large amount of concurrent data at the same time, or is there any reason how to analyze this data can be synchronized, the statistics of the various tables of the data can be consistent with each other, and accurate and consistent with each other

I have also built three tables, one is the user table, which has a total volume of clicks;

The other is a daily table.

Another is the hour meter, which counts the hourly click-out scale for each user.



     // Statistical total click-through volume


                dbc.prepareStatement (
                    "update users set outscore = outscore +? where username =?");
                dbc.setDouble (1, unitscoredouble);
                dbc.setString (2, outname);
                dbc.executeUpdate ();
                // Statistics of the daily order volume
                dbc.prepareStatement (
                    "select username from userdayhistory where username =? and dotyearmonth =? and dotday =?");
                dbc.setString (1, outname);
                dbc.setInt (2, yyyyMM);
                dbc.setInt (3, d);
                rs = dbc.executeQuery ();
                if (rs.next ()) {
                  dbc.prepareStatement (
                      "update userdayhistory set outscore = outscore +? where username =? and dotyearmonth =? and dotday =?");
                  dbc.setDouble (1, unitscoredouble);
                  dbc.setString (2, outname);
                  dbc.setInt (3, yyyyMM);
                  dbc.setInt (4, d);
                  dbc.executeUpdate ();
                }
                else {
                  try {
                    dbc.prepareStatement ("INSERT INTO userdayhistory (username, outscore, putscore, dotyearmonth, dotday) VALUES (?,?,?,?,?)");
                    dbc.setString (1, outname);
                    dbc.setDouble (2, unitscoredouble);
                    dbc.setInt (3, 0);
                    dbc.setInt (4, yyyyMM);
                    dbc.setInt (5, d);
                    dbc.executeUpdate ();
                  }
                  catch (SQLException ex7) {
                    System.out.println ("494");

                  }
                }
                // Statistical hourly output
                dbc.prepareStatement (
                    "select username from userhourhistory where username =? and dotyearmonthday =? and dothour =?");
                dbc.setString (1, outname);
                dbc.setInt (2, yyyyMMdd);
                dbc.setInt (3, H);
                rs = dbc.executeQuery ();
                if (rs.next ()) {
                  dbc.prepareStatement (
                      "update userhourhistory set outscore = outscore +? where username =? and dotyearmonthday =? and dothour =?");
                  dbc.setDouble (1, unitscoredouble);
                  dbc.setString (2, outname);
                  dbc.setInt (3, yyyyMMdd);
                  dbc.setInt (4, H);
                  dbc.executeUpdate ();
                }
                else {
                  try {
                    dbc.prepareStatement ("INSERT INTO userhourhistory (username, outscore, putscore, dotyearmonthday, dothour) VALUES (?,?,?,?,?)");
                    dbc.setString (1, outname);
                    dbc.setDouble (2, unitscoredouble);
                    dbc.setInt (3, 0);
                    dbc.setInt (4, yyyyMMdd);
                    dbc.setInt (5, H);
                    dbc.executeUpdate ();
                  }
                  catch (SQLException ex11) {
                    System.out.println ("9994");

                  }
                }
Reply

Use magic Report

1

Threads

4

Posts

3.00

Credits

Newbie

Rank: 1

Credits
3.00

 China

Post time: 2020-1-4 23:15:01
| Show all posts
Do you want to enable transactions?
Reply

Use magic Report

1

Threads

5

Posts

6.00

Credits

Newbie

Rank: 1

Credits
6.00

 China

 Author| Post time: 2020-1-14 20:45:01
| Show all posts
Where is it going?
Reply

Use magic Report

1

Threads

5

Posts

6.00

Credits

Newbie

Rank: 1

Credits
6.00

 China

 Author| Post time: 2020-1-17 18:45:01
| Show all posts
top
Reply

Use magic Report

1

Threads

5

Posts

6.00

Credits

Newbie

Rank: 1

Credits
6.00

 China

 Author| Post time: 2020-1-20 23:18:01
| Show all posts
top
Reply

Use magic Report

0

Threads

3

Posts

4.00

Credits

Newbie

Rank: 1

Credits
4.00

 China

Post time: 2020-1-23 19:09:01
| Show all posts
Your own design is not reasonable.
Reply

Use magic Report

1

Threads

5

Posts

6.00

Credits

Newbie

Rank: 1

Credits
6.00

 China

 Author| Post time: 2020-2-9 14:15:01
| Show all posts
How to design
Reply

Use magic Report

You have to log in before you can reply Login | Register

Points Rules

Contact us|Archive|Mobile|CopyRight © 2008-2023|verysource.com ( 京ICP备17048824号-1 )

Quick Reply To Top Return to the list