BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
sasphd
Lapis Lazuli | Level 10

I want to delete rows.

this is my program

data flux0;

set flux;

if mtna='T' then delete;

run;

I have this message???????????????

ERROR: LIKE operator requires character operands.

1 ACCEPTED SOLUTION

Accepted Solutions
art297
Opal | Level 21

I'm going to guess that you left off a colon (i.e., =: rather than =), but that your problem is that you are trying to delete records that contain .T, not the character value 'T'.

Try the following:

data flux0;

  set flux;

  if mtna =.T then delete;

run;

View solution in original post

2 REPLIES 2
Astounding
PROC Star

Nope.  No way.  Didn't happen.  That message could not possible emerge from that DATA step.

Check for a missing semicolon on the statement before the DATA statement.  Make sure you have a blank before the word "then".  Otherwise, you will just have to post your log.

Good luck.

art297
Opal | Level 21

I'm going to guess that you left off a colon (i.e., =: rather than =), but that your problem is that you are trying to delete records that contain .T, not the character value 'T'.

Try the following:

data flux0;

  set flux;

  if mtna =.T then delete;

run;

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

What is Bayesian Analysis?

Learn the difference between classical and Bayesian statistical approaches and see a few PROC examples to perform Bayesian analysis in this video.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 2 replies
  • 1186 views
  • 0 likes
  • 3 in conversation