Welcome to today's lesson on applying data filtering and aggregation in a real-world scenario using a user management system in Go. We'll start by building a foundational structure that can handle basic user operations. Then, we'll expand it by introducing more advanced functionalities that allow filtering and aggregating user data.
In our starter task, we will implement a set of functions that manage basic operations on a collection of user data, specifically handling adding new users, retrieving user profiles, and updating user profiles.
Here are the starter task methods:
addUser(userID string, age int, country string, subscribed bool) bool- Adds a new user with the specified attributes. The parameters are passed by value since you're providing complete new values for the addition, and there's no need to track changes after the function call. Returnstrueif the user was added successfully andfalseif a user with the sameuserIDalready exists.getUser(userID string) *UserProfile- Returns a pointer to the user's profile if the user exists; otherwise, returnsnil.updateUser(userID string, age *int, country *string, subscribed *bool) bool- Updates the user's profile based on non-nil parameters. Differently fromaddUser, notice the use of pointers which allows for selective updates; by passing anil, you indicate that a specific field should remain unchanged. Returnstrueif the user exists and was updated;falseotherwise.
To store the user data, we will define a UserProfile struct.
Here is the implementation of our starter task in Go:
The code provides a basic user management system in Go:
- It uses the
UserProfilestruct to store user details such as age, country, and subscription status. - The
UserManagerstruct manages user profiles in a map, with user IDs as keys. - The
NewUserManagerfunction initializesUserManagerwith an empty map of users.
This method filters users based on the criteria provided. Let's see how it works:
In this code snippet:
- The
filterUsersmethod filters users based onminAge,maxAge,country, andsubscribedstatus criteria. - It iterates over the
usersmap and checks each user's profile against the provided criteria. - Users who meet all the criteria are added to the
filteredUserslist, which is then returned. - The example usage shows how to add users and filter them based on different criteria.
This method aggregates statistics from the user profiles. Let's implement it:
Let's discuss this new functionality:
- The
aggregateStatsmethod calculates and returns aggregate statistics about the users in the form of a map. - It determines
totalUsersas the total number of users. - If there are no users, it returns a map with zeroed statistics.
- It calculates
totalAgeby summing the ages of all users. - It computes
subscribedCountby counting the users who are subscribed. - It computes
averageAgeby dividingtotalAgebytotalUsers. - It calculates
subscribedRatioby dividing by .
Great job! Today, you've learned how to effectively handle user data in Go by implementing advanced functionalities like filtering and aggregation on top of a basic system. This is a critical skill in real-life software development, where you often need to extend existing systems to meet new requirements.
I encourage you to practice solving similar challenges to solidify your understanding of data filtering and aggregation in Go. Happy coding, and see you in the next lesson!
