Python、R、Scala等连接数据库


Python连接数据库
   1、安装cx_Oracle包
     http://cx-oracle.sourceforge.net/
   2、安装Oracle Instant Client软件包
     http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html
    查看Oracle版本,可以通过SQL Plus命令行输入:select * from v$version;

   示例:
    import cx_Oracle
    conn = cx_Oracle.connect("oracle.jdbc.driver.OracleDriver","jdbc:oracle:thin:@localhost:1521:xe","scott","1234")  
    cursor = conn.cursor ()
    cursor.execute ("select * from dual")
    row = cursor.fetchone ()
    print row[0]
    cursor.close ()
    conn.close ()

R连接数据库
     方法一:
         设置ODBC数据源(必须Oracle服务端才可用)
         控制面板>管理工具>ODBC数据源
     > library(RODBC)  ##加载RODBC包,没有成功的请先下载安装install.packages("RODBC")
     > con<-odbcConnect("oracle",uid="testuser",pwd="testuser",believeNRows=FALSE) ##建立Oracle连接
     > emp1<-sqlQuery(con,"select * from EMP") ##sqlQuery可带查询语句
     > sqlFetch(con,'EMP')  ##sqlFetch可根据表名,获取Oracle中的表(注意,这里表名在单引号中,双引号会报错)
     > odbcClose(con)  ##关闭连接

     方法二:

    1.将驱动"ojdbc6_g.jar"放到R的工作空间中,不知道R工作空间的可以通过在RStudio中输入"getwd()"查看路径。
    与 ojdbc6.jar 一样,除了类通过“javac -g”编译并包含跟踪代码。
    > library(RJDBC)  ##加载"RJDBC"包,如果失败了。请安装该包install.packages("RJDBC")
    > drv<-JDBC("oracle.jdbc.driver.OracleDriver","ojdbc6_g.jar", identifier.quote="\"")  ##java中JDBC的套路
    > > conn<-dbConnect(drv,"jdbc:oracle:thin:@localhost:1521:xe","scott","1234") ##建立一个连接
    > a<-dbGetQuery(conn,"select * from student") ##根据连接和表名获取Oracle中的表
    > head(EMP,3)  ##查看前三行
    > names(table1)=iconv(names(table1),"UTF-8","GBK")  ##若是表中列名为中文,读取时出现乱码,可用这句来搞定乱码情况
        >dbDisconnect(conn)


Scala连接数据库(其实就是JAVA连接数据库,用的都是Java中的包)
        将需要的Jar包导入工程,有关版本
    import java.sql.Connection
    import java.sql.DriverManager
    import scala.collection.mutable.ArrayBuffer
    object get_oracle {
      def main(args:Array[String]){
        val url = "jdbc:oracle:thin:@localhost:1521:xe"
        // 驱动名称
        val driver = "oracle.jdbc.driver.OracleDriver"
        // 用户名
        val username = "scott"
        // 密码
        val password = "1234"
        // 初始化数据连接
        val connection:Connection = null
        // 初始化查询结果
        val result = ArrayBuffer[String]()
        try {
          // 注册Driver
          Class.forName(driver)
          println("开始尝试连接数据库")
          // 连接数据库
          val connection = DriverManager.getConnection(url, username, password)
          println("数据库连接成功")
          val statement = connection.createStatement
          val rs = statement.executeQuery("select * from student")
          var i = 1
          while(rs.next){
        val item = rs.getString("name")
        result.append(item)
        i = i + 1
          } 
          println("查询数据条数:" + result.length)
          for(index<-result){
        println("具体数据如下:"+index)
          }
         }
        finally{
    //      connection.close()
          println("数据查询成功")
        }
      }
    }

     

你可能感兴趣的:(操作知识点)