Perl/C#连接Oracle/SQL Server和简单操作 perl查找字符串

   2023-02-09 学习力0
核心提示:连接数据库是一个很常见也很必须的操作。先将我用到的总结一下。1. Perl 连接数据库Perl 连接数据库的思路都是:1)使用DBI模块; 2)创建数据库连接句柄dbh; 3)利用dbh创建语句句柄sth; 4)利用sth执行sql语句; 5)利用sth处理数据。连接Oracle:my $dbh

连接数据库是一个很常见也很必须的操作。先将我用到的总结一下。


1. Perl 连接数据库

Perl 连接数据库的思路都是:

1)使用DBI模块; 2)创建数据库连接句柄dbh; 3)利用dbh创建语句句柄sth; 4)利用sth执行sql语句; 5)利用sth处理数据。

连接Oracle:

    my $dbh=DBI->connect("DBI:Oracle:host=$hostname;sid=$sid",$username,$passwd);  
      
    ### deal with multi return value  
    my $sql=qq(select uid_der from wbphish_usr_der);  
    $sth->execute();  
    my $sth=$dbh->prepare($sql);  
    $sth->execute() or die;  
    my @uid;  
    while(my @row=$sth->fetchrow_array)  
    {   push @uid,$row[0];}  
      
    ### deal with single return value  
    my $sql="SELECT max(DEMO) FROM phishing"  
    $sth->execute();  
    my $sth=$dbh->prepare($sql);  
    $sth->execute() or die;  
    my $id=$dbh->selectrow_array($sql);  

其中host是数据库server的ip地址,sid为连接的数据库。

连接SQL Server:

    my $dbh = DBI->connect("dbi:ODBC:driver={SQL Server};Server=127.0.0.1;Database=$dbs;UID=$uid;PWD=$pwd");  
    my $sth = $dbh->prepare($sql);  
    $sth->execute();  

其中Server是server的ip地址,这里是local地址,Database为连接的数据库。


2. C# 连接数据库

C# 连接数据库的思路是:

1)连接给定参数建立连接对象; 2)利用连接对象建立SQL语句对象; 3)利用SQL语句对象执行并处理数据。

连接SQL Server:

    namespace ConsoleApplication1  
    {  
        class Program  
        {  
            static void Main(string[] args)  
            {  
                /*Create Connection*/  
                //connection-string(Local Server:127.0.0.1) & SQL-string define  
                string conString = "Server=(local); database=test; uid=sa; password=123456";  
                string sqlString = "select top 10 " + metricName + ",MetricTime from Metric where MetricTime > @metricTime order by MetricTime";  
                //create a connection  
                SqlConnection con = new SqlConnection(conString);  
                con.Open();  
                  
                /*First way*/  
                //create a SQL command within connection, use SqlDataReader(light-level) to read retrieved data  
                SqlCommand cmd = new SqlCommand(sqlString, con);  
                SqlParameter[] sps = new SqlParameter[] { new SqlParameter("@metricTime", metricTime) };  //Use SqlParameter to avoid "SQL injection".  
                cmd.Parameters.AddRange(sps);  
                SqlDataReader sdr = cmd.ExecuteReader();  
                //Read data from DataReader  
                while (sdr.Read())  
                    Console.WriteLine((double)sdr[metricName]);  
      
                con.Close();  
                cmd.Dispose();  
      
      
      
                /*Second way*/  
                //create a SQL command within connection, use SqlDataAdapter to read retrieved data  
                SqlDataAdapter sqlDad = new SqlDataAdapter(sqlString, sqlCon);              
                SqlParameter sqlPar = new SqlParameter("@metricTime", metricTime);   //Use SqlParameter to avoid "SQL injection".  
                sqlDad.SelectCommand.Parameters.Add(sqlPar);  
                DataSet metricDS = new DataSet("MetricDS");  
                sqlDad.Fill(metricDS, "Metric");            
                //Read data from DataSet  
                foreach (DataRow row in dst.Tables["Monitor"].Rows)  
                    Console.WriteLine(row["ID"] + "\t" + row["RecordTime"] + "\t" + row["VideoView"] + "\t" + row["Fluency"]);  
      
                sqlCon.Close();  
            }  
        }  
    }  

其中连接字串中Server是数据库server的ip地址,database是指定连接的数据库。

代码首先建立连接,然后分别以SqlDataReader和SqlDataAdapter两种方式处理了数据,且利用了SqlParameter来避免SQL injection。


 

以上看来,连接数据库的时候,你得告诉程序:

1)我去连接哪个数据库server呀,2)我连到server了,我去连哪个数据库呀?不然我的sql语句找不到table么。 3)连接之后,我可以有多种方式取得数据

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • Linux下安装Perl和Perl的DBI模块
    今天在虚拟机测试shell脚本的时候,有些命令使用不了。比如说 mysqlhotcopy ,它提示Perl的版本太低。我用的 RedHat9 的Perl才5.8.0版本。。。(2002年以前的)严重过时。所以重新安装了新版本的 Perl,过程记录如下: 1、在官方网站下载新版本的源码包:http:
    03-16
  • Perl 与Form
    说明事项: 這個範例用來說明如何經由網頁上的HTML form 表單元件來呼叫伺服器端的perl 程式。这个范例用来说明如何经由网页上的HTML form 表单元件来呼叫伺服器端的perl 程式。首先在網頁上設計表單元件,這個範例是設計一個按鈕,其原始碼如下:首先在网页
    02-10
  • Perl学习 perl培训
    http://www.sun126.com/perl5/perl5-1.htm翻译: flamephoenix 第一章 概述一、Perl是什么?二、Perl在哪里?三、运行四、注释一、Perl是什么?  Perl是Practical Extraction and Report Language的缩写,它是由Larry Wall设计的,并由他不断更新和维护,用
    02-10
  • - calm_水手">Perl中的箭头符-> - calm_水手
    Perl中的箭头符-2012-05-21 17:14 calm_水手 阅读(623) 评论(0) 编辑 收藏 举报  有两种用法,都和解引用有关。第一种用法,就是解引用。根据 - 后面跟的符号的不同,解不同类型的引用,-[] 表示解数组引用,-{} 表示解散列引用,-() 表示解子程序引
    02-09
  • Regex in Perl
    Regex in Perl
    regex literal   代表正则文字, 就是 m/regex/ 部分中的 regex, 这部分有自己的解析规则. 用 Perl 的行话就是 "表示正则含义的双引号字符串(regx-aware double-quoted string)", 及处理后传递给正则引擎的结果. 正则文字支持的特性:  1. 变量插值.    
    02-09
  • perl脚本语言学习 perl脚本调用perl脚本
    来公司的第二个星期便看了一下perl语言,发现掌握一门脚本语言还是非常有用的。到现在为止已经入职两个月,用perl脚本做了这些活:1. 修改了公司的一个爬取网页源代码的脚本2. 改进了一个出特征库的脚本,根据svn status的状态,来优化,将只需要添加的DB的数
    02-09
  • Perl模块的安装方法 perl 安装模块
    1. 下载离线安装包 *.tar.gz的形式解包后,#perl Makefile.PL#make#make install2. 在联网的情况下,通过CPAN安装# perl -MCPAN -e shellcpan install PAR::Packer 
    02-09
  • Perl像C一样强大,像awk、sed等脚本描述语言一
    Perl是由Larry Wall设计的,并由他不断更新和维护的编程语言。Perl具有高级语言(如C)的强大能力和灵活性。事实上,你将看到,它的许多特性是从C语言中借用来的。Perl与 脚本语言一样,Perl不需要编译器和链接器来运行代码,你要做的只是写出程序并告诉Perl
    02-09
  • 27-Perl 进程管理
    1.Perl 进程管理Perl 中你可以以不同的方法来创建进程。本教程将讨论一些进程的管理方法。你可以使用特殊变量 $$ 或 $PROCESS_ID 来获取进程 ID。%ENV 哈希存放了父进程,也就是shell中的环境变量,在Perl中可以修改这些变量。exit() 通常用于退出子进程,主
    02-09
  • 在perl中简单的正则匹配 正则匹配或的使用
    (一)、在perl中关于元字符的匹配元字符代表含义点号( .)匹配处换行符以外的任何单字符星号(*)匹配前面的内容零次或多次反斜线屏蔽元字符的特殊含义。\\代表\,\.匹配点号.*匹配所有的字符串加号(+)匹配前一个条目一次以上问号(?)表示前面一个条目可
    02-09
点击排行