搜尋
首頁資料庫mysql教程学习MySQL多表操作和备份处理_MySQL


  多表操作
  在一个数据库中,可能存在多个表,这些表都是相互关联的。我们继续使用前面的例子。前面建立的表中包含了员工的一些基本信息,如姓名、性别、出生日期、出生地。我们再创建一个表,该表用于描述员工所发表的文章,内容包括作者姓名、文章标题、发表日期。
  
  1、查看第一个表mytable的内容:
  
  mysql> select * from mytable;
  +----------+------+------------+-----------+
  | name | sex | birth | birthaddr |
  +----------+------+------------+-----------+
  | abccs |f | 1977-07-07 | china |
  | mary |f | 1978-12-12 | usa |
  | tom |m | 1970-09-02 | usa |
  +----------+------+------------+-----------+
  
  2、创建第二个表title(包括作者、文章标题、发表日期):
  
  mysql> create table title(writer varchar(20) not null,
  -> title varchar(40) not null,
  -> senddate date);
      向该表中填加记录,最后表的内容如下:
  
    bordercolorlight = "black" bordercolordark = "#FFFFFF" align="center">
  
  

  
<ccid_code> mysql> select * from title;<br>  +--------+-------+------------+<br>  | writer | title | senddate |<br>  +--------+-------+------------+<br>  | abccs | a1 | 2000-01-23 |<br>  | mary | b1 | 1998-03-21 |<br>  | abccs | a2 | 2000-12-04 |<br>  | tom | c1 | 1992-05-16 |<br>  | tom | c2 | 1999-12-12 |<br>  +--------+-------+------------+<br>  5 rows in set (0.00sec)<br>  <br>  <b>3、多表查询</b><br>  现在我们有了两个表: mytable 和 title。利用这两个表我们可以进行组合查询:<br>  例如我们要查询作者abccs的姓名、性别、文章:<br>  <br>  mysql> SELECT name,sex,title FROM mytable,title<br>  -> WHERE name=writer AND name=′abccs′;<br>  +-------+------+-------+<br>  | name | sex | title |<br>  +-------+------+-------+<br>  | abccs | f | a1 |<br>  | abccs | f | a2 |<br>  +-------+------+-------+<br>  <br>  上面例子中,由于作者姓名、性别、文章记录在两个不同表内,因此必须使用组合来进行查询。必须要指定一个表中的记录如何与其它表中的记录进行匹配。<br>  <br>  注意:如果第二个表title中的writer列也取名为name(与mytable表中的name列相同)而不是writer时,就必须用mytable.name和title.name表示,以示区别。<br>  <br>  再举一个例子,用于查询文章a2的作者、出生地和出生日期:<br>  <br>  mysql> select title,writer,birthaddr,birth from mytable,title<br>  -> where mytable.name=title.writer and title=′a2′;<br>  +-------+--------+-----------+------------+<br>  | title | writer | birthaddr | birth |<br>  +-------+--------+-----------+------------+<br>  | a2 | abccs | china | 1977-07-07 |<br>  +-------+--------+-----------+------------+<br>  <br>  <b>修改和备份、批处理</b><br>  有时我们要对数据库表和数据库进行修改和删除,可以用如下方法实现:<br>  <br>  1、增加一列:<br>  如在前面例子中的mytable表中增加一列表示是否单身single:<br>  mysql> alter table mytable add column single char(1);<br>  <br>  2、修改记录<br>  将abccs的single记录修改为“y”:<br>  mysql> update mytable set single=′y′ where name=′abccs′;   现在来看看发生了什么:<br>  <br>  mysql> select * from mytable;<br>  +----------+------+------------+-----------+--------+<br>  | name | sex | birth | birthaddr | single |<br>  +----------+------+------------+-----------+--------+<br>  | abccs |f | 1977-07-07 | china | y |<br>  | mary |f | 1978-12-12 | usa | NULL |<br>  | tom |m | 1970-09-02 | usa | NULL |<br>  +----------+------+------------+-----------+--------+<br>  <br>  3、增加记录<br>  前面已经讲过如何增加一条记录,为便于查看,重复与此:<br>  <br>  mysql> insert into mytable<br>  -> values (′abc′,′f′,′1966-08-17′,′china′,′n′);<br>  Query OK, 1 row affected (0.05 sec)<br>  <br>  查看一下:<br>  <br>  mysql> select * from mytable;<br>  +----------+------+------------+-----------+--------+<br>  | name | sex | birth | birthaddr | single |<br>  +----------+------+------------+-----------+--------+<br>  | abccs |f | 1977-07-07 | china | y |<br>  | mary |f | 1978-12-12 | usa | NULL |<br>  | tom |m | 1970-09-02 | usa | NULL |<br>  | abc |f | 1966-08-17 | china | n |<br>  +----------+------+------------+-----------+--------+<br>  <br>  4、删除记录<br>  用如下命令删除表中的一条记录:mysql> delete from mytable where name=′abc′;<br>  DELETE从表中删除满足由where给出的条件的一条记录。<br>  再显示一下结果:<br>  <br>  mysql> select * from mytable;<br>  +----------+------+------------+-----------+--------+<br>  | name | sex | birth | birthaddr | single |<br>  +----------+------+------------+-----------+--------+<br>  | abccs |f | 1977-07-07 | china | y |<br>  | mary |f | 1978-12-12 | usa | NULL |<br>  | tom |m | 1970-09-02 | usa | NULL |<br>  +----------+------+------------+-----------+--------+<br>  <br>  5、删除表:<br>  mysql> drop table ****(表1的名字),***表2的名字;<br>  可以删除一个或多个表,小心使用。<br>  <br>  6、数据库的删除:<br>  mysql> drop database 数据库名;<br>  小心使用。<br>  <br>  7、数据库的备份:<br>  退回到DOS:<br>  mysql> quit<br>  d:mysqlbin<br>  <br>  使用如下命令对数据库abccs进行备份:<br>  mysqldump --opt abccs>abccs.dbb<br>  abccs.dbb就是你的数据库abccs的备份文件。<br>  <br>  8、用批处理方式使用MySQL:<br>  <br>  首先建立一个批处理文件mytest.sql,内容如下:<br>  <br>  use abccs;<br>  select * from mytable;<br>  select name,sex from mytable where name=′abccs′;<br>  <br>  在DOS下运行如下命令:d:mysqlbin mysql   <br>  在屏幕上会显示执行结果。<br>  <br>  如果想看结果,而输出结果很多,则可以用这样的命令: mysql   <br>  我们还可以将结果输出到一个文件中: mysql  mytest.out
    </ccid_code>
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
MySQL如何處理數據複製?MySQL如何處理數據複製?Apr 28, 2025 am 12:25 AM

MySQL通過異步、半同步和組複製三種模式處理數據複製。 1)異步複製性能高但可能丟失數據。 2)半同步複製提高數據安全性但增加延遲。 3)組複製支持多主複製和故障轉移,適用於高可用性需求。

您如何使用解釋性語句分析查詢性能?您如何使用解釋性語句分析查詢性能?Apr 28, 2025 am 12:24 AM

EXPLAIN語句可用於分析和提升SQL查詢性能。 1.執行EXPLAIN語句查看查詢計劃。 2.分析輸出結果,關注訪問類型、索引使用情況和JOIN順序。 3.根據分析結果,創建或調整索引,優化JOIN操作,避免全表掃描,以提升查詢效率。

您如何備份並還原MySQL數據庫?您如何備份並還原MySQL數據庫?Apr 28, 2025 am 12:23 AM

使用mysqldump進行邏輯備份和MySQLEnterpriseBackup進行熱備份是備份MySQL數據庫的有效方法。 1.使用mysqldump備份數據庫:mysqldump-uroot-pmydatabase>mydatabase_backup.sql。 2.使用MySQLEnterpriseBackup進行熱備份:mysqlbackup--user=root--password=password--backup-dir=/path/to/backupbackup。恢復時,使用相應的命

MySQL中慢速查詢的常見原因是什麼?MySQL中慢速查詢的常見原因是什麼?Apr 28, 2025 am 12:18 AM

MySQL慢查詢的主要原因包括索引缺失或不當使用、查詢複雜度、數據量過大和硬件資源不足。優化建議包括:1.創建合適的索引;2.優化查詢語句;3.使用分錶分區技術;4.適當升級硬件。

MySQL中有什麼看法?MySQL中有什麼看法?Apr 28, 2025 am 12:04 AM

MySQL視圖是基於SQL查詢結果的虛擬表,不存儲數據。 1)視圖簡化複雜查詢,2)增強數據安全性,3)維護數據一致性。視圖是數據庫中的存儲查詢,可像表一樣使用,但數據動態生成。

MySQL和其他SQL方言之間的語法有什麼區別?MySQL和其他SQL方言之間的語法有什麼區別?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit,自動啟動,弦樂範圍,子征服和表面上分析。 1)MySqluessLipslimit,whilesqlserverusestopopandoraclesrontersrontsrontsrontsronnum.2)

什麼是mysql分區?什麼是mysql分區?Apr 27, 2025 am 12:23 AM

MySQL分區能提升性能和簡化維護。 1)通過按特定標準(如日期範圍)將大表分成小塊,2)物理上將數據分成獨立文件,3)查詢時MySQL可專注於相關分區,4)查詢優化器可跳過不相關分區,5)選擇合適的分區策略並定期維護是關鍵。

您如何在MySQL中授予和撤銷特權?您如何在MySQL中授予和撤銷特權?Apr 27, 2025 am 12:21 AM

在MySQL中,如何授予和撤銷權限? 1.使用GRANT語句授予權限,如GRANTALLPRIVILEGESONdatabase_name.TO'username'@'host';2.使用REVOKE語句撤銷權限,如REVOKEALLPRIVILEGESONdatabase_name.FROM'username'@'host',確保及時溝通權限變更。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能