But I don't think this is correct way creating tables and dropping tables and selecting data twice
It's fine the way it is except for the drops at the end. No need for those.
The only data you're selecting more than once is the data that's actually being returned and that will be quite small compared to what's in the log.
I suppose you could use OPENROWSET to execute the xp directly for such a thing but that's probably a level of sophistication that won't be worth it here.
--Jeff Moden
Change is inevitable... Change for the better is not.