찾다
데이터 베이스MySQL 튜토리얼가상 호스트가 없는 소규모 MySQL 데이터베이스 백업 스크립트

최근 작업에서는 원격 서버에 있는 Mysql 데이터베이스를 로컬 머신에 백업해야 하는 경우가 종종 있는데, 처음에는 Mysql 데이터 디렉터리를 직접 백업하는 방법을 사용했는데, 인코딩이 달라서 문제가 자주 발생했습니다. 나중에 친구가 나에게 매우 편리하고 컴팩트한 PHP 프로그램인 MyDB를 사용하라고 추천했습니다. 총 3개의 파일이 들어있습니다.

1. mydb.php //DB 클래스

코드는 다음과 같습니다.

<? 
class db{ 
var $linkid; 
var $sqlid; 
var $record; 
function db($host="",$username="",$password="",$database="") 
    { 
    if(!$this->linkid)  @$this->linkid = mysql_connect($host, $username, $password) or die("连接服务器失败."); 
    @mysql_select_db($database,$this->linkid) or die("无法打开数据库"); 
    return $this->linkid;} 
function query($sql) 
    {if($this->sqlid=mysql_query($sql,$this->linkid)) return $this->sqlid; 
    else { 
        $this->err_report($sql,mysql_error); 
    return false;} 
    } 
function nr($sql_id="") 
    {if(!$sql_id) $sql_id=$this->sqlid; 
    return mysql_num_rows($sql_id);} 
function nf($sql_id="") 
    {if(!$sql_id) $sql_id=$this->sqlid; 
    return mysql_num_fields($sql_id);} 
function nextrecord($sql_id="") 
    {if(!$sql_id) $sql_id=$this->sqlid; 
    if($this->record=mysql_fetch_array($sql_id))  return $this->record; 
    else return false; 
    } 
function f($name) 
    { 
    if($this->record[$name]) return $this->record[$name]; 
    else return false; 
    } 
function close() {mysql_close($this->linkid);} 
function lock($tblname,$op="WRITE") 
    {if(mysql_query("lock tables ".$tblname." ".$op)) return true; else return false;} 
function unlock() 
    {if(mysql_query("unlock tables")) return true; else return false;} 
function ar() { 
    return @mysql_affected_rows($this->linkid); 
  } 
function i_id() { 
        return mysql_insert_id(); 
    } 
function err_report($sql,$err) 
    { 
echo "Mysql查询错误<br>"; 
echo "查询语句:".$sql."<br>"; 
echo "错误信息:".$err; 
    } 
/****************************************类结束***************************/ 
}?>


2. php // 백업 스크립트

코드는 다음과 같습니다.

<? 
global $mysqlhost, $mysqluser, $mysqlpwd, $mysqldb; 
$mysqlhost="localhost"; //host name 
$mysqluser="root";              //login name 
$mysqlpwd="";              //password 
$mysqldb="";        //name of database 
include("mydb.php"); 
$d=new db($mysqlhost,$mysqluser,$mysqlpwd,$mysqldb); 
/*--------------界面--------------*/if(!$_POST[&#39;act&#39;]){/*----------------------*/ 
$msgs[]="服务器备份目录为backup"; 
$msgs[]="对于较大的数据表,强烈建议使用分卷备份"; 
$msgs[]="只有选择备份到服务器,才能使用分卷备份功能"; 
show_msg($msgs); 
?> 
<form name="form1" method="post" action="backup.php"> 
  <table width="99%" border="1" cellpadding=&#39;0&#39; cellspacing=&#39;1&#39;> 
    <tr align="center" class=&#39;header&#39;><td colspan="2">数据备份</td></tr> 
    <tr><td colspan="2">备份方式</td></tr> 
    <tr><td><input type="radio" name="bfzl" value="quanbubiao">        备份全部数据</td><td>备份全部数据表中的数据到一个备份文件</td></tr> 
    <tr><td><input type="radio" name="bfzl" value="danbiao">备份单张表数据  
        <select name="tablename"><option value="">请选择</option> 
          <? 
        $d->query("show table status from $mysqldb"); 
        while($d->nextrecord()){ 
        echo "<option value=&#39;".$d->f(&#39;Name&#39;)."&#39;>".$d->f(&#39;Name&#39;)."</option>";} 
        ?> 
        </select></td><td>备份选中数据表中的数据到单独的备份文件</td></tr> 
    <tr><td colspan="2">使用分卷备份</td></tr> 
    <tr><td colspan="2"><input type="checkbox" name="fenjuan" value="yes"> 
        分卷备份 <input name="filesize" type="text" size="10">K</td></tr> 
    <tr><td colspan="2">选择目标位置</td></tr> 
    <tr><td colspan="2"><input type="radio" name="weizhi" value="server" checked>备份到服务器</td></tr><tr class="cells"><td colspan=&#39;2&#39;> <input type="radio" name="weizhi" value="localpc"> 
        备份到本地</td></tr> 
    <tr><td colspan="2" align=&#39;center&#39;><input type="submit" name="act" value="备份"></td></tr> 
  </table></form> 
<?/*-------------界面结束-------------*/}/*---------------------------------*/ 
/*----*/else{/*--------------主程序-----------------------------------------*/ 
if($_POST[&#39;weizhi&#39;]=="localpc"&&$_POST[&#39;fenjuan&#39;]==&#39;yes&#39;) 
    {$msgs[]="只有选择备份到服务器,才能使用分卷备份功能"; 
show_msg($msgs); pageend();} 
if($_POST[&#39;fenjuan&#39;]=="yes"&&!$_POST[&#39;filesize&#39;]) 
    {$msgs[]="您选择了分卷备份功能,但未填写分卷文件大小"; 
show_msg($msgs); pageend();} 
if($_POST[&#39;weizhi&#39;]=="server"&&!writeable("./backup")) 
    {$msgs[]="备份文件存放目录&#39;./backup&#39;不可写,请修改目录属性"; 
show_msg($msgs); pageend();} 
/*----------备份全部表-------------*/if($_POST[&#39;bfzl&#39;]=="quanbubiao"){/*----*/ 
/*----不分卷*/if(!$_POST[&#39;fenjuan&#39;]){/*--------------------------------*/ 
if(!$tables=$d->query("show table status from $mysqldb")) 
    {$msgs[]="读数据库结构错误"; show_msg($msgs); pageend();} 
$sql=""; 
while($d->nextrecord($tables)) 
    { 
    $table=$d->f("Name"); 
    $sql.=make_header($table); 
    $d->query("select * from $table"); 
    $num_fields=$d->nf(); 
    while($d->nextrecord()) 
    {$sql.=make_record($table,$num_fields);} 
    } 
$filename=date("Ymd",time())."_all.sql"; 
if($_POST[&#39;weizhi&#39;]=="localpc") down_file($sql,$filename); 
elseif($_POST[&#39;weizhi&#39;]=="server") 
    {if(write_file($sql,$filename)) 
$msgs[]="全部数据表数据备份完成,生成备份文件&#39;./backup/$filename&#39;"; 
    else $msgs[]="备份全部数据表失败"; 
    show_msg($msgs); 
    pageend(); 
    } 
/*-----------------不要卷结束*/}/*-----------------------*/ 
/*-----------------分卷*/else{/*-------------------------*/ 
if(!$_POST[&#39;filesize&#39;]) 
    {$msgs[]="请填写备份文件分卷大小"; show_msg($msgs);pageend();} 
if(!$tables=$d->query("show table status from $mysqldb")) 
    {$msgs[]="读数据库结构错误"; show_msg($msgs); pageend();} 
$sql=""; $p=1; 
$filename=date("Ymd",time())."_all"; 
while($d->nextrecord($tables)) 
{ 
    $table=$d->f("Name"); 
    $sql.=make_header($table); 
    $d->query("select * from $table"); 
    $num_fields=$d->nf(); 
    while($d->nextrecord()) 
    {$sql.=make_record($table,$num_fields); 
    if(strlen($sql)>=$_POST[&#39;filesize&#39;]*1000){ 
            $filename.=("_v".$p.".sql"); 
            if(write_file($sql,$filename)) 
            $msgs[]="全部数据表-卷-".$p."-数据备份完成,生成备份文件&#39;./backup/$filename&#39;"; 
            else $msgs[]="备份表-".$_POST[&#39;tablename&#39;]."-失败"; 
            $p++; 
            $filename=date("Ymd",time())."_all"; 
            $sql="";} 
    } 
} 
if($sql!=""){$filename.=("_v".$p.".sql");         
if(write_file($sql,$filename)) 
$msgs[]="全部数据表-卷-".$p."-数据备份完成,生成备份文件&#39;./backup/$filename&#39;";} 
show_msg($msgs); 
/*---------------------分卷结束*/}/*--------------------------------------*/ 
/*--------备份全部表结束*/}/*---------------------------------------------*/ 
/*--------备份单表------*/elseif($_POST[&#39;bfzl&#39;]=="danbiao"){/*------------*/ 
if(!$_POST[&#39;tablename&#39;]) 
    {$msgs[]="请选择要备份的数据表"; show_msg($msgs); pageend();} 
/*--------不分卷*/if(!$_POST[&#39;fenjuan&#39;]){/*-------------------------------*/ 
$sql=make_header($_POST[&#39;tablename&#39;]); 
$d->query("select * from ".$_POST[&#39;tablename&#39;]); 
$num_fields=$d->nf(); 
while($d->nextrecord()) 
    {$sql.=make_record($_POST[&#39;tablename&#39;],$num_fields);} 
$filename=date("Ymd",time())."_".$_POST[&#39;tablename&#39;].".sql"; 
if($_POST[&#39;weizhi&#39;]=="localpc") down_file($sql,$filename); 
elseif($_POST[&#39;weizhi&#39;]=="server") 
    {if(write_file($sql,$filename)) 
$msgs[]="表-".$_POST[&#39;tablename&#39;]."-数据备份完成,生成备份文件&#39;./backup/$filename&#39;"; 
    else $msgs[]="备份表-".$_POST[&#39;tablename&#39;]."-失败"; 
    show_msg($msgs); 
    pageend(); 
    } 
/*----------------不要卷结束*/}/*------------------------------------*/ 
/*----------------分卷*/else{/*--------------------------------------*/ 
if(!$_POST[&#39;filesize&#39;]) 
    {$msgs[]="请填写备份文件分卷大小"; show_msg($msgs);pageend();} 
$sql=make_header($_POST[&#39;tablename&#39;]); $p=1;  
    $filename=date("Ymd",time())."_".$_POST[&#39;tablename&#39;]; 
    $d->query("select * from ".$_POST[&#39;tablename&#39;]); 
    $num_fields=$d->nf(); 
    while ($d->nextrecord())  
    {     
        $sql.=make_record($_POST[&#39;tablename&#39;],$num_fields); 
       if(strlen($sql)>=$_POST[&#39;filesize&#39;]*1000){ 
            $filename.=("_v".$p.".sql"); 
            if(write_file($sql,$filename)) 
            $msgs[]="表-".$_POST[&#39;tablename&#39;]."-卷-".$p."-数据备份完成,生成备份文件&#39;./backup/$filename&#39;"; 
            else $msgs[]="备份表-".$_POST[&#39;tablename&#39;]."-失败"; 
            $p++; 
            $filename=date("Ymd",time())."_".$_POST[&#39;tablename&#39;]; 
            $sql="";} 
    } 
if($sql!=""){$filename.=("_v".$p.".sql");         
if(write_file($sql,$filename)) 
$msgs[]="表-".$_POST[&#39;tablename&#39;]."-卷-".$p."-数据备份完成,生成备份文件&#39;./backup/$filename&#39;";} 
show_msg($msgs); 
/*----------分卷结束*/}/*--------------------------------------------------*/ 
/*----------备份单表结束*/}/*----------------------------------------------*/ 
/*---*/}/*-------------主程序结束------------------------------------------*/ 
function write_file($sql,$filename) 
{ 
$re=true; 
if(!@$fp=fopen("./backup/".$filename,"w+")) {$re=false; echo "failed to open target file";} 
if(!@fwrite($fp,$sql)) {$re=false; echo "failed to write file";} 
if(!@fclose($fp)) {$re=false; echo "failed to close target file";} 
return $re; 
} 
function down_file($sql,$filename) 
{ 
    ob_end_clean(); 
    header("Content-Encoding: none"); 
    header("Content-Type: ".(strpos($_SERVER[&#39;HTTP_USER_AGENT&#39;], &#39;MSIE&#39;) ? &#39;application/octetstream&#39; : &#39;application/octet-stream&#39;)); 
    header("Content-Disposition: ".(strpos($_SERVER[&#39;HTTP_USER_AGENT&#39;], &#39;MSIE&#39;) ? &#39;inline; &#39; : &#39;attachment; &#39;)."filename=".$filename); 
    header("Content-Length: ".strlen($sql)); 
    header("Pragma: no-cache"); 
    header("Expires: 0"); 
    echo $sql; 
    $e=ob_get_contents(); 
    ob_end_clean(); 
} 
function writeable($dir) 
{ 
    if(!is_dir($dir)) { 
    @mkdir($dir, 0777); 
    } 
    if(is_dir($dir))  
    { 
    if($fp = @fopen("$dir/test.test", &#39;w&#39;)) 
        { 
@fclose($fp); 
    @unlink("$dir/test.test"); 
    $writeable = 1; 
}  
    else { 
$writeable = 0; 
    } 
} 
    return $writeable; 
} 
function make_header($table) 
{global $d; 
$sql="DROP TABLE IF EXISTS ".$table."\n"; 
$d->query("show create table ".$table); 
$d->nextrecord(); 
$tmp=preg_replace("/\n/","",$d->f("Create Table")); 
$sql.=$tmp."\n"; 
return $sql; 
} 
function make_record($table,$num_fields) 
{global $d; 
$comma=""; 
$sql .= "INSERT INTO ".$table." VALUES("; 
for($i = 0; $i < $num_fields; $i++)  
{$sql .= ($comma."&#39;".mysql_escape_string($d->record[$i])."&#39;"); $comma = ",";} 
$sql .= ")\n"; 
return $sql; 
} 
function show_msg($msgs) 
{ 
$title="提示:"; 
echo "<table width=&#39;100%&#39; border=&#39;1&#39;  cellpadding=&#39;0&#39; cellspacing=&#39;1&#39;>"; 
echo "<tr><td>".$title."</td></tr>"; 
echo "<tr><td><br><ul>"; 
while (list($k,$v)=each($msgs)) 
    { 
    echo "<li>".$v."</li>"; 
    } 
echo "</ul></td></tr></table>"; 
} 
function pageend() 
{ 
exit(); 
} 
?>


3.restore.php //복원 스크립트

코드

<? 
session_start(); 
global $mysqlhost, $mysqluser, $mysqlpwd, $mysqldb; 
$mysqlhost="localhost"; //host name 
$mysqluser="root";              //login name 
$mysqlpwd="";              //password 
$mysqldb="";        //name of database 
include("mydb.php"); 
$d=new db($mysqlhost,$mysqluser,$mysqlpwd,$mysqldb); 
/******界面*/if(!$_POST[&#39;act&#39;]&&!$_SESSION[&#39;data_file&#39;]){/**********************/ 
$msgs[]="本功能在恢复备份数据的同时,将全部覆盖原有数据,请确定是否需要恢复,以免造成数据损失"; 
$msgs[]="数据恢复功能只能恢复由dShop导出的数据文件,其他软件导出格式可能无法识别"; 
$msgs[]="从本地恢复数据需要服务器支持文件上传并保证数据尺寸小于允许上传的上限,否则只能使用从服务器恢复"; 
$msgs[]="如果您使用了分卷备份,只需手工导入文件卷1,其他数据文件会由系统自动导入"; 
show_msg($msgs); 
?> 
<form action="" method="post" enctype="multipart/form-data" name="restore.php"> 
<table width="91%" border="0" cellpadding="0" cellspacing="1"> 
<tr align="center" class="header"><td colspan="2" align="center">数据恢复</td></tr> 
<tr><td width="33%"><input type="radio" name="restorefrom" value="server" checked> 
从服务器文件恢复 </td><td width="67%"><select name="serverfile"> 
    <option value="">-请选择-</option> 
<? 
$handle=opendir(&#39;./backup&#39;); 
while ($file = readdir($handle)) { 
    if(eregi("^[0-9]{8,8}([0-9a-z_]+)(\.sql)$",$file)) echo "<option value=&#39;$file&#39;>$file</option>";} 
closedir($handle);  
?> 
  </select> </td></tr> 
<tr><td><input type="radio" name="restorefrom" value="localpc">       从本地文件恢复</td> 
<td><input type="hidden" name="MAX_FILE_SIZE" value="1500000"><input type="file" name="myfile"></td></tr> 
<tr><td colspan="2" align="center"> <input type="submit" name="act" value="恢复"></td>  </tr></table></form> 
<?/**************************界面结束*/}/*************************************/ 
/****************************主程序*/if($_POST[&#39;act&#39;]=="恢复"){/**************/ 
/***************服务器恢复*/if($_POST[&#39;restorefrom&#39;]=="server"){/**************/ 
if(!$_POST[&#39;serverfile&#39;]) 
    {$msgs[]="您选择从服务器文件恢复备份,但没有指定备份文件"; 
     show_msg($msgs); pageend();    } 
if(!eregi("_v[0-9]+",$_POST[&#39;serverfile&#39;])) 
    {$filename="./backup/".$_POST[&#39;serverfile&#39;]; 
    if(import($filename)) $msgs[]="备份文件".$_POST[&#39;serverfile&#39;]."成功导入数据库"; 
    else $msgs[]="备份文件".$_POST[&#39;serverfile&#39;]."导入失败"; 
    show_msg($msgs); pageend();         
    } 
else 
    { 
    $filename="./backup/".$_POST[&#39;serverfile&#39;]; 
    if(import($filename)) $msgs[]="备份文件".$_POST[&#39;serverfile&#39;]."成功导入数据库"; 
    else {$msgs[]="备份文件".$_POST[&#39;serverfile&#39;]."导入失败";show_msg($msgs);pageend();} 
    $voltmp=explode("_v",$_POST[&#39;serverfile&#39;]); 
    $volname=$voltmp[0]; 
    $volnum=explode(".sq",$voltmp[1]); 
    $volnum=intval($volnum[0])+1; 
    $tmpfile=$volname."_v".$volnum.".sql"; 
    if(file_exists("./backup/".$tmpfile)) 
        { 
        $msgs[]="程序将在3秒钟后自动开始导入此分卷备份的下一部份:文件".$tmpfile.",请勿手动中止程序的运行,以免数据库结构受损"; 
        $_SESSION[&#39;data_file&#39;]=$tmpfile; 
        show_msg($msgs); 
        sleep(3); 
        echo "<script language=&#39;javascript&#39;>";  
        echo "location=&#39;restore.php&#39;;";  
        echo "</script>";  
        } 
    else 
        { 
        $msgs[]="此分卷备份全部导入成功"; 
        show_msg($msgs); 
        } 
    } 
/**************服务器恢复结束*/}/********************************************/ 
/*****************本地恢复*/if($_POST[&#39;restorefrom&#39;]=="localpc"){/**************/ 
    switch ($_FILES[&#39;myfile&#39;][&#39;error&#39;]) 
    { 
    case 1: 
    case 2: 
    $msgs[]="您上传的文件大于服务器限定值,上传未成功"; 
    break; 
    case 3: 
    $msgs[]="未能从本地完整上传备份文件"; 
    break; 
    case 4: 
    $msgs[]="从本地上传备份文件失败"; 
    break; 
    case 0: 
    break; 
    } 
    if($msgs){show_msg($msgs);pageend();} 
$fname=date("Ymd",time())."_".sjs(5).".sql"; 
if (is_uploaded_file($_FILES[&#39;myfile&#39;][&#39;tmp_name&#39;])) { 
    copy($_FILES[&#39;myfile&#39;][&#39;tmp_name&#39;], "./backup/".$fname);} 
if (file_exists("./backup/".$fname))  
    { 
    $msgs[]="本地备份文件上传成功"; 
    if(import("./backup/".$fname)) {$msgs[]="本地备份文件成功导入数据库"; unlink("./backup/".$fname);} 
    else $msgs[]="本地备份文件导入数据库失败"; 
    } 
else ($msgs[]="从本地上传备份文件失败"); 
show_msg($msgs); 
/****本地恢复结束*****/}/****************************************************/ 
/****************************主程序结束*/}/**********************************/ 
/*************************剩余分卷备份恢复**********************************/ 
if(!$_POST[&#39;act&#39;]&&$_SESSION[&#39;data_file&#39;]) 
{ 
    $filename="./backup/".$_SESSION[&#39;data_file&#39;]; 
    if(import($filename)) $msgs[]="备份文件".$_SESSION[&#39;data_file&#39;]."成功导入数据库"; 
    else {$msgs[]="备份文件".$_SESSION[&#39;data_file&#39;]."导入失败";show_msg($msgs);pageend();} 
    $voltmp=explode("_v",$_SESSION[&#39;data_file&#39;]); 
    $volname=$voltmp[0]; 
    $volnum=explode(".sq",$voltmp[1]); 
    $volnum=intval($volnum[0])+1; 
    $tmpfile=$volname."_v".$volnum.".sql"; 
    if(file_exists("./backup/".$tmpfile)) 
        { 
        $msgs[]="程序将在3秒钟后自动开始导入此分卷备份的下一部份:文件".$tmpfile.",请勿手动中止程序的运行,以免数据库结构受损"; 
        $_SESSION[&#39;data_file&#39;]=$tmpfile; 
        show_msg($msgs); 
        sleep(3); 
        echo "<script language=&#39;javascript&#39;>";  
        echo "location=&#39;restore.php&#39;;";  
        echo "</script>";  
        } 
    else 
        { 
        $msgs[]="此分卷备份全部导入成功"; 
        unset($_SESSION[&#39;data_file&#39;]); 
        show_msg($msgs); 
        } 
} 
/**********************剩余分卷备份恢复结束*******************************/ 
function import($fname) 
{global $d; 
$sqls=file($fname); 
foreach($sqls as $sql) 
    { 
    str_replace("\r","",$sql); 
    str_replace("\n","",$sql); 
    if(!$d->query(trim($sql))) return false; 
    } 
return true; 
} 
function show_msg($msgs) 
{ 
$title="提示:"; 
echo "<table width=&#39;100%&#39; border=&#39;1&#39;  cellpadding=&#39;0&#39; cellspacing=&#39;1&#39;>"; 
echo "<tr><td>".$title."</td></tr>"; 
echo "<tr><td><br><ul>"; 
while (list($k,$v)=each($msgs)) 
    { 
    echo "<li>".$v."</li>"; 
    } 
echo "</ul></td></tr></table>"; 
} 
function pageend() 
{ 
exit(); 
} 
?>

파일 구조가 매우 명확합니다. 파일 2와 3에 데이터베이스 서버의 주소, 사용자 이름, 비밀번호만 설정하면 데이터를 백업하고 복원할 수 있습니다.

·사용 시 내보낸 스크립트를 저장할 수 있는 쓰기 권한이 있는 동일한 수준 디렉터리 아래에 백업 디렉터리를 생성해야 합니다.
·백업 데이터베이스가 비교적 큰 경우 서버 스크립트 시간 초과를 늘려야 합니다.
·볼륨 백업을 지원합니다. 복원 시 볼륨 백업의 첫 번째 스크립트를 선택하기만 하면 모든 스크립트가 자동으로 복원됩니다.
·볼륨 파일 크기는 너무 커서는 안 되며, 2MB를 넘지 않는 것이 좋습니다.
·보안상의 이유로 스크립트를 사용하지 않을 때는 서버에서 삭제하는 것을 잊지 마세요.

[관련 추천]

1. Mysql 무료 동영상 튜토리얼

Mysql 시작 및 중지 방법을 알려줍니다. services

3. mysql의 특수 sql 문 처리 예제 튜토리얼

테이블 삭제를 위한 sql 문 작성 방법에 대한 자세한 설명 다른 데이터베이스에서

5. 한 머신에서 여러 MySQL 서비스를 실행하는 방법 알아보기

위 내용은 가상 호스트가 없는 소규모 MySQL 데이터베이스 백업 스크립트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL의 라이센스는 다른 데이터베이스 시스템과 어떻게 비교됩니까?MySQL의 라이센스는 다른 데이터베이스 시스템과 어떻게 비교됩니까?Apr 25, 2025 am 12:26 AM

MySQL은 GPL 라이센스를 사용합니다. 1) GPL 라이센스는 MySQL의 무료 사용, 수정 및 분포를 허용하지만 수정 된 분포는 GPL을 준수해야합니다. 2) 상업용 라이센스는 공개 수정을 피할 수 있으며 기밀이 필요한 상업용 응용 프로그램에 적합합니다.

MyISAM을 통해 언제 innodb를 선택 하시겠습니까?MyISAM을 통해 언제 innodb를 선택 하시겠습니까?Apr 25, 2025 am 12:22 AM

MyISAM 대신 InnoDB를 선택할 때의 상황에는 다음이 포함됩니다. 1) 거래 지원, 2) 높은 동시성 환경, 3) 높은 데이터 일관성; 반대로, MyISAM을 선택할 때의 상황에는 다음이 포함됩니다. 1) 주로 읽기 작업, 2) 거래 지원이 필요하지 않습니다. InnoDB는 전자 상거래 플랫폼과 같은 높은 데이터 일관성 및 트랜잭션 처리가 필요한 응용 프로그램에 적합하지만 MyISAM은 블로그 시스템과 같은 읽기 집약적 및 트랜잭션이없는 애플리케이션에 적합합니다.

MySQL에서 외국 키의 목적을 설명하십시오.MySQL에서 외국 키의 목적을 설명하십시오.Apr 25, 2025 am 12:17 AM

MySQL에서 외국 키의 기능은 테이블 간의 관계를 설정하고 데이터의 일관성과 무결성을 보장하는 것입니다. 외국 키는 참조 무결성 검사 및 계단식 작업을 통해 데이터의 효과를 유지합니다. 성능 최적화에주의를 기울이고 사용할 때 일반적인 오류를 피하십시오.

MySQL의 다른 유형의 인덱스는 무엇입니까?MySQL의 다른 유형의 인덱스는 무엇입니까?Apr 25, 2025 am 12:12 AM

MySQL에는 B-Tree Index, Hash Index, Full-Text Index 및 공간 인덱스의 네 가지 주요 인덱스 유형이 있습니다. 1.B- 트리 색인은 범위 쿼리, 정렬 및 그룹화에 적합하며 직원 테이블의 이름 열에서 생성에 적합합니다. 2. HASH 인덱스는 동등한 쿼리에 적합하며 메모리 저장 엔진의 HASH_Table 테이블의 ID 열에서 생성에 적합합니다. 3. 전체 텍스트 색인은 기사 테이블의 내용 열에서 생성에 적합한 텍스트 검색에 사용됩니다. 4. 공간 지수는 지리 공간 쿼리에 사용되며 위치 테이블의 Geom 열에서 생성에 적합합니다.

MySQL에서 인덱스를 어떻게 생성합니까?MySQL에서 인덱스를 어떻게 생성합니까?Apr 25, 2025 am 12:06 AM

toreateanindexinmysql, usethecreateindexstatement.1) forasinglecolumn, "createindexidx_lastnameonemployees (lastname);"2) foracompositeIndex를 사용하고 "createDexIdx_nameonemployees (forstName, FirstName);"3)을 사용하십시오

MySQL은 sqlite와 어떻게 다릅니 까?MySQL은 sqlite와 어떻게 다릅니 까?Apr 24, 2025 am 12:12 AM

MySQL과 Sqlite의 주요 차이점은 설계 개념 및 사용 시나리오입니다. 1. MySQL은 대규모 응용 프로그램 및 엔터프라이즈 수준의 솔루션에 적합하며 고성능 및 동시성을 지원합니다. 2. SQLITE는 모바일 애플리케이션 및 데스크탑 소프트웨어에 적합하며 가볍고 내부질이 쉽습니다.

MySQL의 색인이란 무엇이며 성능을 어떻게 향상 시키는가?MySQL의 색인이란 무엇이며 성능을 어떻게 향상 시키는가?Apr 24, 2025 am 12:09 AM

MySQL의 인덱스는 데이터 검색 속도를 높이는 데 사용되는 데이터베이스 테이블에서 하나 이상의 열의 주문 구조입니다. 1) 인덱스는 스캔 한 데이터의 양을 줄임으로써 쿼리 속도를 향상시킵니다. 2) B-Tree Index는 균형 잡힌 트리 구조를 사용하여 범위 쿼리 및 정렬에 적합합니다. 3) CreateIndex 문을 사용하여 CreateIndexIdx_customer_idonorders (customer_id)와 같은 인덱스를 작성하십시오. 4) Composite Indexes는 CreateIndexIdx_customer_orderOders (Customer_id, Order_Date)와 같은 다중 열 쿼리를 최적화 할 수 있습니다. 5) 설명을 사용하여 쿼리 계획을 분석하고 피하십시오

MySQL에서 트랜잭션을 사용하여 데이터 일관성을 보장하는 방법을 설명하십시오.MySQL에서 트랜잭션을 사용하여 데이터 일관성을 보장하는 방법을 설명하십시오.Apr 24, 2025 am 12:09 AM

MySQL에서 트랜잭션을 사용하면 데이터 일관성이 보장됩니다. 1) STARTTRANSACTION을 통해 트랜잭션을 시작한 다음 SQL 작업을 실행하고 커밋 또는 롤백으로 제출하십시오. 2) SavePoint를 사용하여 부분 롤백을 허용하는 저장 지점을 설정하십시오. 3) 성능 최적화 제안에는 트랜잭션 시간 단축, 대규모 쿼리 방지 및 격리 수준을 합리적으로 사용하는 것이 포함됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구