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

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[];} ### 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. maven 插件
  2. LAMP一键安装脚本 from:秋水逸冰
  3. B2B电子商务网站技术框架
  4. 网站为什么要做SEO
  5. [codevs1154][COJ0177][NOIP2006]能量项链
  6. ios中怎么样判断路径最后的后缀名称
  7. javascript实现map的功能(转载)
  8. js 闭包 详解
  9. 关于VMware导入Linux VM找不到网卡的问题
  10. python 网络编程第三版
  11. 开启cocos2dx 3.0的Console功能
  12. C#压缩字符串
  13. mock.js的真实数据模拟
  14. docker中的镜像中运行Django项目
  15. python中经典类和新式类的区别
  16. mssql instead of 触发器应用一-创建只读视图(view)的方法
  17. es6的模块化--AMD/CMD/commonJS/ES6
  18. java项目使用mvn打包时,出现数据库连接错误
  19. IOS-一步一步教你自定义评分星级条RatingBar
  20. webpack入门指南-step01

热门文章

  1. 开启关闭Centos的自动更新(转)
  2. Echarts无数据时只显示文字不显示动画
  3. 使用IDEA创建package
  4. python3读取html文件
  5. 织梦默认分页样式改动 解决分页列表显示,去掉li
  6. 蓝点通用管理系统V13版发布了!
  7. Linux启动U盘制作
  8. B1:模板方法模式 TemplateMethod
  9. ibatis--百度百科
  10. 【MyBatis】MyBatis分页插件PageHelper的使用