Perl/C#连接Oracle/SQL Server

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


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
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值