cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
thomasw1964
Helper III
Helper III

Creating Recurrence flow for updating column based on number of days

 

  • In the flow, add a condition to check the "Start Date" field:

    • If the "Start Date" is within the first 30 days, set a variable to "Phase1."
    • If the "Start Date" is over 30 days but within 365 days, set the variable to "Phase2."
    • If the "Start Date" is over 365 days, set the variable to "Phase3."
  • Update the SharePoint item's phase column with the value stored in the variable.

  • I have been trying different stuff all day with Conditional Formatting , but then learned it won't automatically update
  • I am lost on the logic here in Powerautomate

thomasw1964_1-1695755953697.png

 

 

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
wskinnermctc
Super User
Super User

You need to use the field in the Get Items that says Filter Query. Use that to only get items less than or equal 30 days and the phase column does not equal "Phase1".

This way it only gets items that need the Phase1 updated.

 

Look at this link Microsoft Learn In Depth Get Items that explains how the filter query is used in Get Items.

 

To just update the Phase1 items it will look something like this below and use the filter query:

 

StartDate le 'addDays(utcNow(),30)' and PhaseColumn ne 'Phase1'

 

The Get Items looks like below with the filter query above.

Get Items with StartDate less or equals 30 days and Phase Column does not equal Phase1Get Items with StartDate less or equals 30 days and Phase Column does not equal Phase1

 

Then after the update less than 30 day items. You can add another get items that is filtered by between 30 and 365 days. So this will only update the Phase2 items.

The Get Items will use the Filter Query:

 

(StartDate gt 'addDays(utcNow(),30)' and StartDate lt 'addDays(utcNow(),365)') and PhaseColumn ne 'Phase2'

 

In the flow it will look like this below:

Get Items between 30 days and 365 days and update with Phase2Get Items between 30 days and 365 days and update with Phase2

 

After the Phase2 you can add another Get Items that will only update items greater than 365 days and need to be changed to Phase3.

StartDate gt 'addDays(utcNow(),365)' and PhaseColumn ne 'Phase3'

It will look like this below

Get Items greater than 365 days and PhaseColumn not equal to 'Phase3'Get Items greater than 365 days and PhaseColumn not equal to 'Phase3'

 

So basically you have 3 different Get Items that will only get the items within a date range and update them if they have not already had the phase updated.

 

Please review Microsoft Learn In-Depth Get Items that has a great example to reference.

View solution in original post

35 REPLIES 35
wskinnermctc
Super User
Super User

How many rows/items do you expect to be in this sharepoint list? 

 

Your plan is not complicated, but it will be doing a lot of duplicate update if you don't do some additional checks. 


For example if you have 30 Items with a StartDate in 30 days.

  • The schedule flow runs today and updates all 30 items to Phase1
  • Tomorrow the schedule flow runs and updates all 30 items to Phase1
  • Thursday the schedule flow runs and updates all 30 items to Phase1

That is a lot of wasted data updating. Also your items will look like they were modified everyday.

FLMike
Multi Super User
Multi Super User

Hello

 

Inside your Apply to Each

1. Create a Compose. Rename it to Get Days

Add this expression, remembering to replace where I have Your Date Column

This calculates the days between today and your date column.

 

int(split(dateDifference(formatDateTime(utcNow(), 'MM-dd-yyyy'), formatDateTime(items()?['Your Date Column']), 'MM-dd-yyyy')),'.')[0])

NOTE: If your Date Column is a String then do this instead
int(split(dateDifference(formatDateTime(utcNow(), 'MM-dd-yyyy'), formatDateTime(DateValue(items()?['Your Date Column'])), 'MM-dd-yyyy')),'.')[0])

 

 

2. Create a second Compose. Rename it to Set Phase

 

 

if(lessOrEquals(outputs('Get_Days'), 30), 'Phase 1', 
   if(and(greaterOrEquals(outputs('Get_Days'), 31),lessOrEquals(outputs('Get_Days'), 365)), 'Phase 2', 'Phase 3')
)

 

 

 

Now the Output of Compose two will be Phase 1 or 2 or 3.

 

But as @wskinnermctc  says you could be updating a lot.

 


Cheers
If you like my answer, please Mark it as Resolved, and give it a thumbs up, so it can help others
Thank You
Michael Gernaey MCT | MCSE | MCP | Self-Contractor| Ex-Microsoft
https://gernaeysoftware.com
LinkedIn: https://www.linkedin.com/in/michaelgernaey 

wskinnermctc
Super User
Super User

You need to use the field in the Get Items that says Filter Query. Use that to only get items less than or equal 30 days and the phase column does not equal "Phase1".

This way it only gets items that need the Phase1 updated.

 

Look at this link Microsoft Learn In Depth Get Items that explains how the filter query is used in Get Items.

 

To just update the Phase1 items it will look something like this below and use the filter query:

 

StartDate le 'addDays(utcNow(),30)' and PhaseColumn ne 'Phase1'

 

The Get Items looks like below with the filter query above.

Get Items with StartDate less or equals 30 days and Phase Column does not equal Phase1Get Items with StartDate less or equals 30 days and Phase Column does not equal Phase1

 

Then after the update less than 30 day items. You can add another get items that is filtered by between 30 and 365 days. So this will only update the Phase2 items.

The Get Items will use the Filter Query:

 

(StartDate gt 'addDays(utcNow(),30)' and StartDate lt 'addDays(utcNow(),365)') and PhaseColumn ne 'Phase2'

 

In the flow it will look like this below:

Get Items between 30 days and 365 days and update with Phase2Get Items between 30 days and 365 days and update with Phase2

 

After the Phase2 you can add another Get Items that will only update items greater than 365 days and need to be changed to Phase3.

StartDate gt 'addDays(utcNow(),365)' and PhaseColumn ne 'Phase3'

It will look like this below

Get Items greater than 365 days and PhaseColumn not equal to 'Phase3'Get Items greater than 365 days and PhaseColumn not equal to 'Phase3'

 

So basically you have 3 different Get Items that will only get the items within a date range and update them if they have not already had the phase updated.

 

Please review Microsoft Learn In-Depth Get Items that has a great example to reference.

thomasw1964
Helper III
Helper III

Thank you guys for the assistance,Ii will be trying tomorrow and update this thread , again thanks!

 

Kinda burned out for the day today

This has me the closest but the output on the list came back as

if(lessOrEquals(outputs('Get_Days'), 30), 'Phase 1', if(and(greaterOrEquals(outputs('Get_Days'), 31),lessOrEquals(outputs('Get_Days'), 365)), 'Phase 2', 'Phase 3'))

 

When I use any expression like output() or triggeredoutput() against the output of compose2 the flow fails

I tried many different ways to add the filtering always get a failure on the filtering

thomasw1964_0-1695811911675.png

 

Trying these expressions next

 

concat(slice(outputs('Compose_2'),

add(nthIndexOf(outputs('Compose_2'), ' ', 12), 2),

nthIndexOf(outputs('Compose_2'), ' ', 13)),

substring(outputs('Compose_2'),

add(nthIndexOf(outputs('Compose_2'), ' ', 8), 2), 1))

I see what this did ... ugh it made everyone phase1

Interesting, I did 2 Get Items , the first one checks for Phase1, this allowed me to grab the Dynamic in the second for the Start Date column and do start date le addDays(), 30 and that still fails. I also realized that I need to add client status of Active, as we won't care about updating inactive clients ... we only ever have 160 clients max so I don't think it will be a lot of updating if I filter down to just Active status

thomasw1964
Helper III
Helper III

Think know why my filters are failing , seems you cannot filter on choice columns or conditional columns

Hi,

 

I don't understand what you mean you cannot use the out put from the second Compose. It would have to be how you are using, not that you cannot use it, works fine for me.

 

Helps to share exactly what you did, not just say it didnt work. Pictures of the flow etc.

Your ask was to make it say Phase 1 or Phase 2 or Phase 3, thats exactly what I provided. What choice are you referring too, you didn't mention that before.

 

And yes you can filter on choices. Is it multiselect, single etc?

 

If you wanted something other than provided, please add details and re-write the ask.


Cheers
If you like my answer, please Mark it as Resolved, and give it a thumbs up, so it can help others
Thank You
Michael Gernaey MCT | MCSE | MCP | Self-Contractor| Ex-Microsoft
https://gernaeysoftware.com
LinkedIn: https://www.linkedin.com/in/michaelgernaey

thomasw1964
Helper III
Helper III

I started with recurrence, added a get items(no filter for testing), created an apply to each, inside of that  I created the 2 compose  the 2 compose and followed up with an Update Item.

PA1.JPGPA2.JPGPA3.JPGPA4.JPGPA5.JPG

@thomasw1964 you need to make it look exactly like the pictures and be sure to include the single ' quotes around the addDays expression. (The only difference should be the column names if you have a different name.)

 

You also need to be sure you are using the correct SharePoint column name within the filter query. Please look at this post about SharePoint Column InternalName and see how to determine what should be used within the filter query. Your column name might be Start_x0020_Date or maybe Start_Date depending on how you initially named it.

 

I really believe the example I showed with the three separate Get Items will be the easiest approach. It only requires that you get the Filter Query working. It uses very basic steps.

 

Please read more about the Get Items and Filter Query here.

HI,

 

It's because you pasted them in as string, and not expressions.

 

Also its Get Days, not Get days for the name, the spelling matters when referencing another Action.

 

Also is this a String or a Choice field? 


Cheers
If you like my answer, please Mark it as Resolved, and give it a thumbs up, so it can help others
Thank You
Michael Gernaey MCT | MCSE | MCP | Self-Contractor| Ex-Microsoft
https://gernaeysoftware.com
LinkedIn: https://www.linkedin.com/in/michaelgernaey

@wskinnermctc 

I don't disagree that what you provided works. But if he adds more phases, he will have to keep repeating and adding more sections of the same loop, but with a different filter, versus only updating a single If expression.

 

 

 

 

@FLMike I'm trying to take into account that they don't know how to even write an expression; more less keep updating a complicated one.

If they can figure out how to use a Filter Query first, it can help with making better flows long term or any adjustments. It also simplifies any following steps since all they will have to do is select the choice option in the Update Item step.

 

There should not be an issue with having multiple Get Items if they are only getting the items that needs to be edited. What is less data usage long term? Getting 160 items and updating all of them everyday. Or 3 separate Get Items which may return none, or a couple of items to update?

 

I try to show users what I would do if it was my flow or at least very similar. I would not use an expression with nested if functions that have hard coded references. I don't believe that it is transparent or easily recognized.

 

Plenty of times you can find flows that are difficult to update or correct because so much of the action is happening in some frankenstein expression the last IT person cobbled together just to get the job done. You or I may be able to get in and better recognize issues, but newer users likely won't.

 

IT likes to set things up with the result of if it works, it works. I don't think that is helpful for guiding new users and long term success.

 

Either way, OP seems to be following your example. Hopefully they can figure out how to write the expression.

int(split(dateDifference(formatDateTime(utcNow(), 'MM-dd-yyyy'), formatDateTime(items()?['Your Date Column']), 'MM-dd-yyyy')),'.')[0])

 

This will error when the utcNow() date is the same as the StartDate because there will not be a period '.' in the output. 

You are correct in the fact I am just not getting the expression writing, we will never have more than the 3 phases. But just trying examples of writing the first part of the expression fails for me

 

I have gone back and taken your corrections to my filtering and was missing the '' around the addTime function, I then setup the update item and it ran successfully , but did not put Phase1 in the Phase column

 

I apologize for the lack of knowledge , I've been working with Sharepoint,PowerApps , and Powerautomate for about a month now.. So far I've done OK I think ..Get stuck and eventually get stuff working

 

I changed the filter to look for the ActiveClient eq 'Active'

thomasw1964_0-1695827459506.png

 

I am assuming my issue now is I do not know how to pass Phase1 back to the Phase column

 

thomasw1964_1-1695827525211.png

Thank you for the help so far though I now understand how to write the filters

ClientStatus is filtering, and that would be a good thing as we will only ever have 160 max , we could have a lot more client records for this to look at by going by the phases as we have a pretty good turn over rate on clients not making it through the first 30 days

Helpful resources

Announcements

Tuesday Tip | How to Report Spam in Our Community

It's time for another TUESDAY TIPS, your weekly connection with the most insightful tips and tricks that empower both newcomers and veterans in the Power Platform Community! Every Tuesday, we bring you a curated selection of the finest advice, distilled from the resources and tools in the Community. Whether you’re a seasoned member or just getting started, Tuesday Tips are the perfect compass guiding you across the dynamic landscape of the Power Platform Community.   As our community family expands each week, we revisit our essential tools, tips, and tricks to ensure you’re well-versed in the community’s pulse. Keep an eye on the News & Announcements for your weekly Tuesday Tips—you never know what you may learn!   Today's Tip: How to Report Spam in Our Community We strive to maintain a professional and helpful community, and part of that effort involves keeping our platform free of spam. If you encounter a post that you believe is spam, please follow these steps to report it: Locate the Post: Find the post in question within the community.Kebab Menu: Click on the "Kebab" menu | 3 Dots, on the top right of the post.Report Inappropriate Content: Select "Report Inappropriate Content" from the menu.Submit Report: Fill out any necessary details on the form and submit your report.   Our community team will review the report and take appropriate action to ensure our community remains a valuable resource for everyone.   Thank you for helping us keep the community clean and useful!

Tuesday Tip | How to Get Community Support

It's time for another Tuesday Tip, your weekly connection with the most insightful tips and tricks that empower both newcomers and veterans in the Power Platform Community! Every Tuesday, we bring you a curated selection of the finest advice, distilled from the resources and tools in the Community. Whether you’re a seasoned member or just getting started, Tuesday Tips are the perfect compass guiding you across the dynamic landscape of the Power Platform Community.       This Week: All About Community Support Whether you're a seasoned community veteran or just getting started, you may need a bit of help from time to time! If you need to share feedback with the Community Engagement team about the community or are looking for ways we can assist you with user groups, events, or something else, Community Support is the place to start.   Community Support is part of every one of our communities, accessible to all our community members.   Within each community's Community Support page, you'll find three distinct areas, each with a different focus to help you when you need support from us most. Power Apps: https://powerusers.microsoft.com/t5/Community-Support/ct-p/pa_community_support Power Automate: https://powerusers.microsoft.com/t5/Community-Support/ct-p/mpa_community_support Power Pages: https://powerusers.microsoft.com/t5/Community-Support/ct-p/mpp_community_support Copilot Studio: https://powerusers.microsoft.com/t5/Community-Support/ct-p/pva_community-support   Community Support Form If you need more assistance, you can reach out to the Community Team via the Community support form. Choose the type of support you require and fill in the form accordingly. We will respond to you promptly.    Thank you for being an active part of our community. Your contributions make a difference!   Best Regards, The Community Management Team

Community Roundup: A Look Back at Our Last 10 Tuesday Tips

As we continue to grow and learn together, it's important to reflect on the valuable insights we've shared. For today's #TuesdayTip, we're excited to take a moment to look back at the last 10 tips we've shared in case you missed any or want to revisit them. Thanks for your incredible support for this series--we're so glad it was able to help so many of you navigate your community experience!   Getting Started in the Community An overview of everything you need to know about navigating the community on one page!  Community Links: ○ Power Apps ○ Power Automate  ○ Power Pages  ○ Copilot Studio    Community Ranks and YOU Have you ever wondered how your fellow community members ascend the ranks within our community? We explain everything about ranks and how to achieve points so you can climb up in the rankings! Community Links: ○ Power Apps ○ Power Automate  ○ Power Pages  ○ Copilot Studio    Powering Up Your Community Profile Your Community User Profile is how the Community knows you--so it's essential that it works the way you need it to! From changing your username to updating contact information, this Knowledge Base Article is your best resource for powering up your profile. Community Links: ○ Power Apps ○ Power Automate  ○ Power Pages  ○ Copilot Studio    Community Blogs--A Great Place to Start There's so much you'll discover in the Community Blogs, and we hope you'll check them out today!  Community Links: ○ Power Apps ○ Power Automate  ○ Power Pages  ○ Copilot Studio    Unlocking Community Achievements and Earning Badges Across the Communities, you'll see badges on users profile that recognize and reward their engagement and contributions. Check out some details on Community badges--and find out more in the detailed link at the end of the article! Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio    Blogging in the Community Interested in blogging? Everything you need to know on writing blogs in our four communities! Get started blogging across the Power Platform communities today! Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio   Subscriptions & Notifications We don't want you to miss a thing in the community! Read all about how to subscribe to sections of our forums and how to setup your notifications! Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio   Getting Started with Private Messages & Macros Do you want to enhance your communication in the Community and streamline your interactions? One of the best ways to do this is to ensure you are using Private Messaging--and the ever-handy macros that are available to you as a Community member! Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio   Community User Groups Learn everything about being part of, starting, or leading a User Group in the Power Platform Community. Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio   Update Your Community Profile Today! Keep your community profile up to date which is essential for staying connected and engaged with the community. Community Links: ○ Power Apps  ○ Power Automate  ○ Power Pages  ○ Copilot Studio   Thank you for being an integral part of our journey.   Here's to many more Tuesday Tips as we pave the way for a brighter, more connected future! As always, watch the News & Announcements for the next set of tips, coming soon!    

Hear what's next for the Power Up Program

Hear from Principal Program Manager, Dimpi Gandhi, to discover the latest enhancements to the Microsoft #PowerUpProgram, including a new accelerated video-based curriculum crafted with the expertise of Microsoft MVPs, Rory Neary and Charlie Phipps-Bennett. If you’d like to hear what’s coming next, click the link below to sign up today! https://aka.ms/PowerUp  

Tuesday Tip: Getting Started with Private Messages & Macros

Welcome to TUESDAY TIPS, your weekly connection with the most insightful tips and tricks that empower both newcomers and veterans in the Power Platform Community! Every Tuesday, we bring you a curated selection of the finest advice, distilled from the resources and tools in the Community. Whether you’re a seasoned member or just getting started, Tuesday Tips are the perfect compass guiding you across the dynamic landscape of the Power Platform Community.   As our community family expands each week, we revisit our essential tools, tips, and tricks to ensure you’re well-versed in the community’s pulse. Keep an eye on the News & Announcements for your weekly Tuesday Tips—you never know what you may learn!   This Week's Tip: Private Messaging & Macros in Power Apps Community   Do you want to enhance your communication in the Community and streamline your interactions? One of the best ways to do this is to ensure you are using Private Messaging--and the ever-handy macros that are available to you as a Community member!   Our Knowledge Base article about private messaging and macros is the best place to find out more. Check it out today and discover some key tips and tricks when it comes to messages and macros:   Private Messaging: Learn how to enable private messages in your community profile and ensure you’re connected with other community membersMacros Explained: Discover the convenience of macros—prewritten text snippets that save time when posting in forums or sending private messagesCreating Macros: Follow simple steps to create your own macros for efficient communication within the Power Apps CommunityUsage Guide: Understand how to apply macros in posts and private messages, enhancing your interaction with the Community For detailed instructions and more information, visit the full page in your community today:Power Apps: Enabling Private Messaging & How to Use Macros (Power Apps)Power Automate: Enabling Private Messaging & How to Use Macros (Power Automate)  Copilot Studio: Enabling Private Messaging &How to Use Macros (Copilot Studio) Power Pages: Enabling Private Messaging & How to Use Macros (Power Pages)

Tuesday Tip: Subscriptions & Notifications

TUESDAY TIPS are our way of communicating helpful things we've learned or shared that have helped members of the Community. Whether you're just getting started or you're a seasoned pro, Tuesday Tips will help you know where to go, what to look for, and navigate your way through the ever-growing--and ever-changing--world of the Power Platform Community! We cover basics about the Community, provide a few "insider tips" to make your experience even better, and share best practices gleaned from our most active community members and Super Users.   With so many new Community members joining us each week, we'll also review a few of our "best practices" so you know just "how" the Community works, so make sure to watch the News & Announcements each week for the latest and greatest Tuesday Tips!   This Week: All About Subscriptions & Notifications We don't want you to a miss a thing in the Community! The best way to make sure you know what's going on in the News & Announcements, to blogs you follow, or forums and galleries you're interested in is to subscribe! These subscriptions ensure you receive automated messages about the most recent posts and replies. Even better, there are multiple ways you can subscribe to content and boards in the community! (Please note: if you have created an AAD (Azure Active Directory) account you won't be able to receive e-mail notifications.)   Subscribing to a Category  When you're looking at the entire category, select from the Options drop down and choose Subscribe.     You can then choose to Subscribe to all of the boards or select only the boards you want to receive notifications. When you're satisfied with your choices, click Save.     Subscribing to a Topic You can also subscribe to a single topic by clicking Subscribe from the Options drop down menu, while you are viewing the topic or in the General board overview, respectively.     Subscribing to a Label Find the labels at the bottom left of a post.From a particular post with a label, click on the label to filter by that label. This opens a window containing a list of posts with the label you have selected. Click Subscribe.     Note: You can only subscribe to a label at the board level. If you subscribe to a label named 'Copilot' at board #1, it will not automatically subscribe you to an identically named label at board #2. You will have to subscribe twice, once at each board.   Bookmarks Just like you can subscribe to topics and categories, you can also bookmark topics and boards from the same menus! Simply go to the Topic Options drop down menu to bookmark a topic or the Options drop down to bookmark a board. The difference between subscribing and bookmarking is that subscriptions provide you with notifications, whereas bookmarks provide you a static way of easily accessing your favorite boards from the My subscriptions area.   Managing & Viewing Your Subscriptions & Bookmarks To manage your subscriptions, click on your avatar and select My subscriptions from the drop-down menu.     From the Subscriptions & Notifications tab, you can manage your subscriptions, including your e-mail subscription options, your bookmarks, your notification settings, and your email notification format.     You can see a list of all your subscriptions and bookmarks and choose which ones to delete, either individually or in bulk, by checking multiple boxes.     A Note on Following Friends on Mobile Adding someone as a friend or selecting Follow in the mobile view does not allow you to subscribe to their activity feed. You will merely be able to see your friends’ biography, other personal information, or online status, and send messages more quickly by choosing who to send the message to from a list, as opposed to having to search by username.

Users online (5,701)