We help IT Professionals succeed at work.

Random String Gerneration in Oracle 9i

Slowang
Slowang asked
on
Medium Priority
1,083 Views
Last Modified: 2007-12-19
Dear All,

I need to generate random strings from a given charset, and length of string in PL/SQL Oracle 9i.

for example,
charset = 'ABcDeFG'
length = 10
A possible random string output would be:
'cDGADBeGAF'

I had a look at the dbms_random.string function.
Unfortunately, this function only returns a random string but it doesn't gerenate the string from a given charset.

Can experts please give me a hand?

Thanks in advance
Comment
Watch Question

Commented:
can you easily generate a random integer with a range?

if you had an array of characters that held your charset you could loop the number of times that your string length needs to be.

array of chars [A, B, c, D, e, F, G]
string length = 10
new string = ''

while new string length < 10
  generate random number between 0 and upper bound of array of chars
  new string = new string + chararray[random number]


Unfortunately, my knowledge of PL-SQL isn't that extensive so I'm not really sure how easy/hard this would be ...
Commented:
I believe this is a completely bullet proof function....

create or replace function random_string(charset in varchar2,string_length in number)
return varchar2 is
random_string varchar2(2000);
charset_length number;
begin
 if string_length not between 1 and 2000 then
   raise_application_error(-20001,'Length must be between 1 and 2000');
 end if;
 charset_length := length(charset);
 if charset is null then raise_application_error(-20002,'Charset must have data');
 end if;
 for n in 1 .. string_length loop
  random_string := random_string ||
    substr(charset,round(dbms_random.value(1,length(charset))),1);
 end loop;
 return random_string;
end;
/

And an execution script to prove it out....

Function created.

SQL> select random_string(null,10) from dual;
select random_string(null,10) from dual
       *
ERROR at line 1:
ORA-20002: Charset must have data
ORA-06512: at "EVTREAD.RANDOM_STRING", line 10
ORA-06512: at line 1


SQL> select random_string('ABC',null) from dual;
select random_string('ABC',null) from dual
       *
ERROR at line 1:
ORA-06502: PL/SQL: numeric or value error
ORA-06512: at "EVTREAD.RANDOM_STRING", line 12


SQL> select random_string('ABC',-5) from dual;
select random_string('ABC',-5) from dual
       *
ERROR at line 1:
ORA-20001: Length must be between 1 and 2000
ORA-06512: at "EVTREAD.RANDOM_STRING", line 7


SQL> select random_string('ABC',10) from dual;

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
ABBCBBCABC

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
BBCBBABAAC

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
BABCABCBBB

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
CBBCCCCCCA

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
CBCBBCBCCB

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
ACACCBABBB

SQL> /

RANDOM_STRING('ABC',10)
----------------------------------------------------------------------------
BCBBCBBBBA

SQL>

Note that there is no attempt to assure that the same character isn't in the string more than one time... so, if you have 'AAAB' as the passed in string, you are going to likely get 3 times as many A's as B's in the return string.... I suspect this is ok though.

Enjoy.

Not the solution you were looking for? Getting a personalized solution is easy.

Ask the Experts

Commented:
have a look at : http://orsweb.com/downloads/source/372.html, u can use it to generate number, charatcters, ...

Commented:
if u want to use special characterset, define it eg as:
"my characterset" VARCHAR(100):='AaBbCcDdEeFf0123456789'
than use
for i in 1..<wanted length of string> loop
  "random num" := generate random number from 1 till lendth of "my characterset";
  "random string" := "random string" || substr("my characterset","random number",1);
end loop;

Author

Commented:
Thanks dudes,

Instead of writing my own functions, I decided to use the dbms_random.string function with the translate function.

After the dbms_random.string function returns a random string, the translate functionto replace the chars that i dont want.

Well, the drawback is that the replacement chars are hardcode, but anyway, it solve my problem~

Thanks again
Access more of Experts Exchange with a free account
Thanks for using Experts Exchange.

Create a free account to continue.

Limited access with a free account allows you to:

  • View three pieces of content (articles, solutions, posts, and videos)
  • Ask the experts questions (counted toward content limit)
  • Customize your dashboard and profile

*This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

OR

Please enter a first name

Please enter a last name

8+ characters (letters, numbers, and a symbol)

By clicking, you agree to the Terms of Use and Privacy Policy.