设为首页 收藏本站
查看: 1246|回复: 0

[经验分享] Perl/C#连接Oracle/SQL Server和简单操作

[复制链接]

尚未签到

发表于 2015-12-27 09:16:37 | 显示全部楼层 |阅读模式
  连接数据库是一个很常见也很必须的操作。先将我用到的总结一下。
  

  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)连接之后,我可以有多种方式取得数据

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-156817-1-1.html 上篇帖子: CentOS Linux Install Core Development Tools Automake, Gcc (C/C++), Perl, Python 下篇帖子: [转载]用perl操作注册表的一些基本函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表