亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? psa-chapter07.txt

?? perl語言的經典文章
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
Example code from Perl for System Administration by David N. Blank-Edelman
O'Reilly and Associates, 1st Edition, ISBN 1-56592-609-9

Chapter Seven
=============

#*
#* connecting/disconnecting to an SQL server using DBI
#*

use DBI;

# connect using to the database named $database using given 
# username and password, return a database handle
$database = "sysadm";
$dbh = DBI->connect("DBI:mysql:$database",$username,$pw);
die "Unable to connect: $DBI::errstr\n" unless (defined $dbh);

$dbh = DBI->connect("DBI:mysql:$database",$username,$pw,{RaiseError => 1});

# <perform tasks>

# tells server you will not need more data from statement handle
# (optional, since we're just about to disconnect)
$sth->finish;  
# disconnects handle from database
$dbh->disconnect;
-------
#*
#* two ways to send commands to an SQL using DBI
#*

$results=$dbh->do(q{UPDATE hosts 
                    SET bldg = 'Main' 
                    WHERE name = 'bendir'});
die "Unable to perform update:$DBI::errstr\n" unless (defined $results)

### OR ###

$sth = $dbh->prepare(q{SELECT * from hosts}) or 
  die "Unable to prep our query:".$dbh->errstr."\n";
$rc = $sth->execute or 
  die "Unable to execute our query:".$dbh->errstr."\n";
-------
#*
#* two examples of placeholder use with DBI
#*

@machines = qw(bendir shimmer sander);
$sth = $dbh->prepare(q{SELECT name, ipaddr FROM hosts WHERE name = ?});
foreach $name (@machines){
  $sth->execute($name);
  #<do-something-with-the-results>
}

### OR ###

$sth->prepare(
   q{SELECT name, ipaddr FROM hosts 
     WHERE (name = ? AND bldg = ? AND dept = ?)});
$sth->execute($name,$bldg,$dept);
-------
#*
#* several ways to retrieve query results using DBI
#*

# the query
$sth = $dbh->prepare(q{SELECT name,ipaddr,dept from hosts}) or
  die "Unable to prepare our query: ".$dbh->errstr."\n";
$sth->execute or die "Unable to execute our query: ".$dbh->errstr."\n";

while ($aref = $sth->fetchrow_arrayref){
  print "name: "   .  $aref->[0] . "\n";
  print "ipaddr: " .  $aref->[1] . "\n";
  print "dept: "   .  $aref->[2] . "\n";
}

### OR ###

while ($href = $sth->fetchrow_hashref){
  print "name: "   .  $href->{name}  . "\n";
  print "ipaddr: " .  $href->{ipaddr}. "\n";
  print "dept: "   .  $href->{dept}  . "\n";
}

### OR ###

$aref_aref = $sth->fetchall_arrayref;
foreach $rowref (@$aref_aref){
  print "name: "   .  $rowref->[0] . "\n";
  print "ipaddr: " .  $rowref->[1] . "\n";
  print "dept: "   .  $rowref->[2] . "\n";
  print '-'x30,"\n";
}

### OR ###

$aref_aref = $sth->fetchall_arrayref;
foreach $rowref (@$aref_aref){
  for ($i=0; $i < $sth->{NUM_OF_FIELDS};i++;){
    print $sth->{NAME}->[$i].": ".$rowref->[$i]."\n";
  } 
  print '-'x30,"\n";
}
-------
#*
#* snippet showing bind_columns from DBI
#*

$sth = $dbh->prepare(q{SELECT name,ipaddr,dept from hosts}) or
  die "Unable to prep our query:".$dbh->errstr".\n";
$rc = $sth->execute or 
  die "Unable to execute our query:".$dbh->errstr".\n";

# these variables will receive the 1st, 2nd and 3rd columns 
# from our SELECT
$rc = $sth->bind_columns(\$name,\$ipaddr,\$dept);

while ($sth->fetchrow_arrayref){
    # $name, $ipaddr, and $dept are automagically filled in from 
    # the fetched query results row
    #<do-something-with-the-results>
}
-------
#*
#* creating a DSN and connecting to a server, disconnecting and removing
#* the DSN using ODBC
#*

# creates a user DSN to a Microsoft SQL Server
# note: to create a system DSN, substitute ODBC_ADD_SYS_DSN 
# for ODBC_ADD_DSN
if (Win32::ODBC::ConfigDSN(
                   ODBC_ADD_DSN, 
                   "SQL Server", 
                   ("DSN=PerlSysAdm", 
                    "DESCRIPTION=DSN for PerlSysAdm", 
                    "SERVER=mssql.happy.edu",  # server name
                    "ADDRESS=192.168.1.4",     # server IP addr
                    "DATABASE=sysadm",         # our database
                    "NETWORK=DBMSSOCN",        # TCP/IP Socket Lib
                   ))){
    print "DSN created\n";
                             }
else {
    die "Unable to create DSN:" . Win32::ODBC::Error() . "\n";
}

# connect to the named DSN, returns a database handle
$dbh=new Win32::ODBC("DSN=PerlSysAdm;UID=$username;PWD=$pw;");
die "Unable to connect to DSN PerlSysAdm:" . Win32::ODBC::Error() . "\n" 
  unless (defined $dbh);

#<perform operations>

$dbh->close();

# replace ODBC_REMOVE_DSN with ODBC_REMOVE_SYS_DSN if you created a system DSN
if (Win32::ODBC::ConfigDSN(ODBC_REMOVE_DSN,
                           "SQL Server","DSN=PerlSysAdm")){
    print "DSN deleted\n";
}
else {
    die "Unable to delete DSN:".Win32::ODBC::Error()."\n";
}
-------
#*
#* two examples of sending queries to an SQL server using ODBC 
#*

$rc = $dbh->Sql(q{SELECT * from hosts});

### OR ###

if (defined $dbh->Sql(q{UPDATE hosts 
                        SET bldg = 'Main' 
                        WHERE name = 'bendir'})){
    die "Unable to perform update: ".Win32::ODBC::Error()."\n"
}
else {
    $results = $dbh->RowCount();
}
-------
#*
#* two ways to retrieve results from a server using ODBC
#*

if ($dbh->FetchRow()){
  @ar = $dbh->Data(); 
  #<do-stuff-with-@ar-values>
}

### OR ###

if ($dbh->FetchRow()){
   $ha = $dbh->DataHash('name','ipaddr'); 
   #<do-stuff-with-$ha{name}-and-$ha{ipaddr}>
}
-------
#*
#* documented an MySQL server using DBI
#*

use DBI;

print "Enter user for connect: ";
chomp($user = <STDIN>);
print "Enter passwd for $user: ";
chomp($pw = <STDIN>);

$start= "mysql"; # connect initially to this database

# connect to the start MySQL database
$dbh = DBI->connect("DBI:mysql:$start",$user,$pw);
die "Unable to connect: ".$DBI::errstr."\n" unless (defined $dbh);

# find the databases on the server 
$sth=$dbh->prepare(q{SHOW DATABASES}) or
  die "Unable to prepare show databases: ". $dbh->errstr."\n";
$sth->execute or
  die "Unable to exec show databases: ". $dbh->errstr."\n";
while ($aref = $sth->fetchrow_arrayref) {
    push(@dbs,$aref->[0]);
} 
$sth->finish;

# find the tables in each database
foreach $db (@dbs) {
    print "---$db---\n";
    
    $sth=$dbh->prepare(qq{SHOW TABLES FROM $db}) or
      die "Unable to prepare show tables: ". $dbh->errstr."\n";
    $sth->execute or
      die "Unable to exec show tables: ". $dbh->errstr."\n";

    @tables=();
    while ($aref = $sth->fetchrow_arrayref) {
	push(@tables,$aref->[0]);
    } 

    $sth->finish;
    
   # find the column info for each table
   foreach $table (@tables) {
       print "\t$table\n";

       $sth=$dbh->prepare(qq{SHOW COLUMNS FROM $table FROM $db}) or
	 die "Unable to prepare show columns: ". $dbh->errstr."\n";
       $sth->execute or
	 die "Unable to exec show columns: ". $dbh->errstr."\n";
       
       while ($aref = $sth->fetchrow_arrayref) {
	   print "\t\t",$aref->[0]," [",$aref->[1],"]\n";
       } 

       $sth->finish;
   }
}
$dbh->disconnect;
-------
#*
#* documenting a Sybase server using DBI
#*

use DBI;

print "Enter user for connect: ";
chomp($user = <STDIN>);
print "Enter passwd for $user: ";
chomp($pw = <STDIN>);

$dbh = DBI->connect('dbi:Sybase:',$user,$pw);
die "Unable to connect: $DBI::errstr\n" 
  unless (defined $dbh);

# find the databases on the server 
$sth = $dbh->prepare(q{SELECT name from master.dbo.sysdatabases}) or
  die "Unable to prepare sysdatabases query: ".$dbh->errstr."\n";
$sth->execute or
  die "Unable to execute sysdatabases query: ".$dbh->errstr."\n";

while ($aref = $sth->fetchrow_arrayref) {
    push(@dbs, $aref->[0]);
}
$sth->finish;

foreach $db (@dbs) {
    $dbh->do("USE $db") or
      die "Unable to use $db: ".$dbh->errstr."\n";
    print "---$db---\n";

    # find the tables in each database
    $sth=$dbh->prepare(q{SELECT name FROM sysobjects WHERE type="U"}) or
      die "Unable to prepare sysobjects query: ".$dbh->errstr."\n";
    $sth->execute or
      die "Unable to exec sysobjects query: ".$dbh->errstr."\n";

    @tables=();
    while ($aref = $sth->fetchrow_arrayref) {
        push(@tables,$aref->[0]);
    } 
    $sth->finish;

    # we need to be "in" the database for the next step
    $dbh->do("use $db") or
      die "Unable to change to $db: ".$dbh->errstr."\n";
  
    # find the column info for each table
    foreach $table (@tables) {
	print "\t$table\n";

	$sth=$dbh->prepare(qq{EXEC sp_columns $table}) or
	  die "Unable to prepare sp_columns query: ".$dbh->errstr."\n";
	$sth->execute or
	  die "Unable to execute sp_columns query: ".$dbh->errstr."\n";
	
	while ($aref = $sth->fetchrow_arrayref) {
	    print "\t\t",$aref->[3]," [",$aref->[5],"(",$aref->[6],")]\n";
	} 
	$sth->finish;
    }
}
$dbh->disconnect or
  warn "Unable to disconnect: ".$dbh->errstr."\n";
-------
#*
#* documenting an MS-SQL server using ODBC
#*

use Win32::ODBC;

print "Enter user for connect: ";
chomp($user = <STDIN>);
print "Enter passwd for $user: ";
chomp($pw = <STDIN>);

$dsn="sysadm"; # name of the DSN we will be using

# find the available DSNs, creating $dsn if it doesn't exist already

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区久久久久| 亚洲欧美在线另类| 国产成人a级片| 成人欧美一区二区三区视频网页| 波多野结衣精品在线| 国产福利91精品一区二区三区| 午夜精品福利在线| 亚洲国产一区二区在线播放| 亚洲手机成人高清视频| 一区二区三区四区激情| 青娱乐精品视频在线| 国产精品综合一区二区三区| 国产xxx精品视频大全| 91免费版在线| 精品久久五月天| 国产精品久久久久影院| 石原莉奈在线亚洲三区| 免费观看在线色综合| 国模少妇一区二区三区| 波多野结衣欧美| 制服丝袜日韩国产| 国产精品灌醉下药二区| 日本va欧美va欧美va精品| 国产成人aaa| 日韩精品一区二区三区四区视频 | 另类小说一区二区三区| 99国产精品99久久久久久| 欧美一区二区不卡视频| 亚洲美女屁股眼交| 成人久久18免费网站麻豆 | 国产福利一区二区三区视频在线| 亚洲精品五月天| 成人少妇影院yyyy| 欧美美女喷水视频| 一区二区三区中文字幕| 亚洲一区二区三区四区在线 | 国产精品一区二区你懂的| 在线观看视频一区二区欧美日韩| 国产视频一区二区在线| 国产毛片精品视频| 精品日韩一区二区三区| 激情六月婷婷久久| 国产亚洲一区二区三区四区| 国产真实乱子伦精品视频| 欧美一级片在线看| 成+人+亚洲+综合天堂| 国产精品女主播av| 日韩三级中文字幕| 色成人在线视频| 国产精品午夜春色av| 欧美视频中文字幕| 久久成人免费日本黄色| 亚洲激情在线激情| 国产欧美日韩卡一| 4438成人网| 欧美亚洲一区二区三区四区| 日本vs亚洲vs韩国一区三区| 中文字幕综合网| 久久综合中文字幕| 日韩一区二区电影在线| 色94色欧美sute亚洲线路一ni| 免费观看在线色综合| 欧美国产日本韩| 亚洲欧美日韩成人高清在线一区| 91年精品国产| 国产日韩欧美a| 粉嫩久久99精品久久久久久夜| 久久久亚洲国产美女国产盗摄| 亚洲一区二区视频| 色爱区综合激月婷婷| 五月综合激情婷婷六月色窝| 日韩欧美视频在线| 一本一本久久a久久精品综合麻豆| 蓝色福利精品导航| 免费精品视频在线| 久久精品72免费观看| 日韩电影一二三区| 日韩综合小视频| 中文字幕一区日韩精品欧美| 国产精品久久久99| 亚洲欧洲中文日韩久久av乱码| 欧美精品一区二区不卡| 欧美日韩国产高清一区二区三区 | 青青草97国产精品免费观看| 国产精品综合二区| 不卡一区二区在线| 欧美在线观看视频一区二区| 92精品国产成人观看免费| 91丨九色丨尤物| 日本道免费精品一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 日韩精品在线网站| 天天亚洲美女在线视频| 成人在线一区二区三区| 91电影在线观看| 亚洲精品在线三区| 亚洲精品福利视频网站| 国产精品亚洲成人| 欧美精品久久久久久久久老牛影院| 欧美变态tickling挠脚心| 亚洲欧美一区二区久久| 国产精品中文字幕日韩精品| 欧美日韩高清一区二区三区| 久久久久国产精品麻豆| 蜜臀av亚洲一区中文字幕| 国产精品影视在线观看| 欧洲精品视频在线观看| 亚洲精品国产一区二区三区四区在线 | 久久国产精品无码网站| 欧美肥妇free| 天天综合色天天| 91免费版在线看| 亚洲综合色自拍一区| 91国产精品成人| 亚洲一线二线三线久久久| av在线不卡电影| 久久精品这里都是精品| 精一区二区三区| 欧美激情中文不卡| 粉嫩高潮美女一区二区三区| 久久久久久久久久久久久夜| 国产一区二区三区四| 国产欧美一区二区精品性色| 成人91在线观看| 日韩一区精品字幕| 欧美精品一区二区三区在线| 日韩福利电影在线| 91麻豆精品91久久久久同性| 亚洲一级二级在线| 欧美撒尿777hd撒尿| 一区二区三区 在线观看视频| 成人午夜电影网站| 一区二区三区在线视频免费观看| 成人免费视频一区二区| 亚洲美女精品一区| 91精品国产综合久久婷婷香蕉| 亚洲国产日日夜夜| 国产欧美日韩麻豆91| 3751色影院一区二区三区| 国产成人在线视频网址| 一区二区三区在线视频观看| 欧美日韩免费电影| 成人高清视频在线观看| 国产精品嫩草久久久久| 欧美日韩激情一区二区三区| 黄网站免费久久| 亚洲品质自拍视频| 久久精品综合网| 欧美日产在线观看| 懂色一区二区三区免费观看| 免费观看日韩av| 一二三四区精品视频| 国产精品久久午夜夜伦鲁鲁| 欧美日韩日日骚| 欧美综合天天夜夜久久| 成人自拍视频在线| 亚洲一区在线观看视频| 国产欧美一区二区精品仙草咪| 色哟哟欧美精品| 99re免费视频精品全部| 激情文学综合丁香| 久久国产精品一区二区| 一区二区三区四区乱视频| 日韩色视频在线观看| 日韩视频一区在线观看| 色婷婷综合视频在线观看| 一本色道久久综合亚洲aⅴ蜜桃 | 欧美放荡的少妇| 精品国产一区二区三区忘忧草| 日韩女优视频免费观看| 日韩精品一区二区在线观看| 欧美一卡二卡三卡四卡| 日韩一区二区麻豆国产| 欧美一区二区精品在线| 精品国产一区二区三区av性色| 日韩精品一区二| 亚洲美女免费视频| 麻豆成人久久精品二区三区红| 国产精品一品二品| 国产成人高清视频| 色婷婷综合久久久久中文| 久久新电视剧免费观看| 精品播放一区二区| 久久精品一级爱片| 综合婷婷亚洲小说| 亚洲一区二区三区中文字幕 | 在线一区二区三区四区五区| 91精品午夜视频| 中文字幕一区三区| 免费成人在线网站| 精品国产乱码久久久久久牛牛| 1000部国产精品成人观看| 久久精品国产亚洲a| 欧美日韩国产经典色站一区二区三区| 在线播放91灌醉迷j高跟美女| 中文字幕乱码日本亚洲一区二区| 午夜精品国产更新| 欧美日韩成人综合在线一区二区 | 日韩不卡在线观看日韩不卡视频| 大白屁股一区二区视频|