Thanks for the tip Gwen. Long story short, got it working (used the link you 
sent, plus a couple other I found to frame up my fix). For posterity/user list 
search sake:

I ended up needing to escape several times inside the pw as I had three special 
characters in there. This worked:

--connect 
jdbc:oracle:thin:username/\"pass\&\!\123\#w\"@xxx.xxx.xxx.xxx:1523/SCHEMA

Fun ☺

From: Gwen Shapira [mailto:[email protected]]
Sent: Monday, June 23, 2014 10:55 AM
To: [email protected]
Subject: Re: Oracle Special Character Password

I think your password is getting mangled by the command line.
Try wrapping it in quotes.

The best way to test what quoting or escaping is needed is to test in SQLPlus.
Something like:


sqlplus nick/"p@ssword\!"@ORCL





Once you figure out how to use the password on the command line with SQLPlus, 
you can use the same thing with Sqoop.



See this blog for an example: 
http://nadvi.blogspot.com/2011/02/oracle-password-with-or-special.html





Gwen

On Mon, Jun 23, 2014 at 7:19 AM, Martin, Nick 
<[email protected]<mailto:[email protected]>> wrote:
Thanks for having a look...tested the user/pw in SQL Developer and worked fine.

CLI:
sqoop import --target-dir /user/NiMartin/xxx/yyyyy --table SCHEMA.TABLE 
--connect 
jdbc:oracle:thin:@xxx.xxx.xxx.com:1523/SCHEMA<http://jdbc:oracle:thin:@xxx.xxx.xxx.com:1523/SCHEMA>
 --username user --password pw --hive-drop-import-delims -m 16 --verbose 
--escaped-by \\ --fields-terminated-by ,


exception:
java.sql.SQLException: ORA-01017: invalid username/password; logon denied

        at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:445)
        at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:389)
        at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:382)
        at oracle.jdbc.driver.T4CTTIfun.processError(T4CTTIfun.java:600)
        at 
oracle.jdbc.driver.T4CTTIoauthenticate.processError(T4CTTIoauthenticate.java:445)
        at oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:450)
        at oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:192)
        at 
oracle.jdbc.driver.T4CTTIoauthenticate.doOAUTH(T4CTTIoauthenticate.java:380)
        at 
oracle.jdbc.driver.T4CTTIoauthenticate.doOAUTH(T4CTTIoauthenticate.java:760)
        at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:401)
        at 
oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:546)
        at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:236)
        at 
oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
        at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:521)
        at java.sql.DriverManager.getConnection(DriverManager.java:571)
        at java.sql.DriverManager.getConnection(DriverManager.java:215)
        at 
org.apache.sqoop.manager.OracleManager.makeConnection(OracleManager.java:322)
        at 
org.apache.sqoop.manager.GenericJdbcManager.getConnection(GenericJdbcManager.java:52)
        at org.apache.sqoop.manager.SqlManager.execute(SqlManager.java:685)
        at org.apache.sqoop.manager.SqlManager.execute(SqlManager.java:708)
        at 
org.apache.sqoop.manager.SqlManager.getColumnTypesForRawQuery(SqlManager.java:243)
        at 
org.apache.sqoop.manager.SqlManager.getColumnTypes(SqlManager.java:226)
        at 
org.apache.sqoop.manager.ConnManager.getColumnTypes(ConnManager.java:347)
        at 
org.apache.sqoop.orm.ClassWriter.getColumnTypes(ClassWriter.java:1298)
        at org.apache.sqoop.orm.ClassWriter.generate(ClassWriter.java:1110)
        at org.apache.sqoop.tool.CodeGenTool.generateORM(CodeGenTool.java:96)
        at org.apache.sqoop.tool.ImportTool.importTable(ImportTool.java:396)
        at org.apache.sqoop.tool.ImportTool.run(ImportTool.java:506)
        at org.apache.sqoop.Sqoop.run(Sqoop.java:147)
        at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:70)
        at org.apache.sqoop.Sqoop.runSqoop(Sqoop.java:183)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:222)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:231)
        at org.apache.sqoop.Sqoop.main(Sqoop.java:240)
14/06/23 10:12:34 ERROR tool.ImportTool: Encountered IOException running import 
job: java.io.IOException: No columns to generate for ClassWriter
        at org.apache.sqoop.orm.ClassWriter.generate(ClassWriter.java:1116)
        at org.apache.sqoop.tool.CodeGenTool.generateORM(CodeGenTool.java:96)
        at org.apache.sqoop.tool.ImportTool.importTable(ImportTool.java:396)
        at org.apache.sqoop.tool.ImportTool.run(ImportTool.java:506)
        at org.apache.sqoop.Sqoop.run(Sqoop.java:147)
        at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:70)
        at org.apache.sqoop.Sqoop.runSqoop(Sqoop.java:183)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:222)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:231)
        at org.apache.sqoop.Sqoop.main(Sqoop.java:240)

-----Original Message-----
From: Jarek Jarcec Cecho [mailto:[email protected]<mailto:[email protected]>]
Sent: Saturday, June 21, 2014 9:55 AM
To: [email protected]<mailto:[email protected]>
Subject: Re: Oracle Special Character Password

Hi Martin,
could you please share your entire command line and exact exception (with stack 
trace) that you're hitting?

Jarcec

On Sat, Jun 21, 2014 at 11:18:33AM +0000, Martin, Nick wrote:
> I do a lot of Oracle imports/exports everyday using Sqoop with good success. 
> However, I keep hitting a gotcha - any time we try to import from an Oracle 
> database that had a password with special characters we get invalid 
> username/pw error.
>
> If we get the password changed to something without a special character it 
> works like a charm. Problem is we're now faced with some databases that have 
> a special character password required so we're kinda hosed.
>
> Using --password via CLI currently.
>
> Any ideas?
>
>
>
> Sent from my iPhone

Reply via email to