Mysql之表的操作與索引操作

来源:http://www.cnblogs.com/wadmwz/archive/2017/09/03/7470370.html
-Advertisement-
Play Games

表的操作: 1.表的創建: create table if not exists table_name(欄位定義); 例子: create table if not exists user(id int auto_increment, uname varchar(20), address varch ...


表的操作: 1.表的創建: create table if not exists table_name(欄位定義); 例子: create table if not exists user(id int auto_increment, uname varchar(20), address varchar(200), updateTime datetime, primary key(id)); // 設置主鍵 2.表(show tables;)定義查看: show create table table_name; DESC table_name; show full columns from table_name; 3.表的更新: (1) 表的重命名:alter table old_user_name rename to new_user_name; rename table old_user_name to new_user_name ; (2) 增加列:alter table table_name add column column_nname(修飾); 在表的第一個位置增加欄位,在語句最後加上FIRST,在表的指定欄位之後添加,在最後加上AFTER 屬性名; 例子:alter table user add column age int not null default 0 after uname;//在uname列後增加age列,並且不為空,預設為0. (3) 刪除列:alter table table_name drop (column) column_name; (4).欄位修改:alter table table_name change cloumn old_column_name new_cloumn_name 屬性名 數據類型; 例子:alter table user change column adddress address varchar(1024) not null default 'beijing';// 將adddress重新命名為address,範圍為1024,不為空,預設值為beijing (5).表的刪除:drop table table_name; (6):複製表:create table new_table_name like old_table_name ; 4.操作表的約束: (1).非空約束(not null); 直接跟在欄位後,比如:name varchar(20) not null; (2).設置欄位預設值(default 預設值); 直接跟在欄位後,比如:name varchar(20) default 'name'; (3).設置唯一約束(unique); 唯一約束指的是不能添加重覆值 ;直接跟在欄位後,比如:name varchar(20) unique; (4).設置主鍵約束(primary key); 單欄位主鍵:constraint pk_name primary key(name);直接跟在欄位後,比如:id int primary key; 多欄位主鍵:constraint pk_name1_name2 primary key(name1, name2);這個語句放在創建表的最後就可以. (5).設置值自動增加(auto_increment);直接跟在欄位後,比如:id int auto_increment; (6).設置外鍵約束(foreign key): 語法:constraint 外鍵約束名 foreign key(屬性名1) references 表名(屬性名2);設置外鍵只能放在外鍵存在的表中,放在建表的最後一句,設置之後 不能插入父表中不存在的值. 語法例子:constraint fk_deptno foreign key(deptno) references t_dept(deptno); 上面6個中除了外間約束和多欄位主鍵約束只能放在創建表的最後一句,其餘都應該放在創建表時的欄位之後,多個約束條件直接緊隨其後.比如:name varchar(20) not null default 'name';//設置name不為空預設值為name.   索引的操作: 1.索引的創建 (1).普通索引: create index index_name on table_name(屬性名); 例子: create index idx_name on users(username); 查詢時:通過explain select * from users where username = "條件";可以看出type為rel,而普通查詢是ALL,也就是全盤掃描,降低效率,建立索引可以提高查找效率. (2).唯一索引(值唯一不可以重覆): create unnqiue index index_unique_name on table_name(屬性名); 例子:create unique index idx_unique_name on users(username); // 不可以添加姓名相同的記錄. (3).主鍵索引(一定是唯一索引,但唯一索引不一定是主鍵索引): alter table table_name add primary key(屬性名); (4).複合索引: alter table table_name add index index_name(屬性名1,屬性名2....); 複合索引只有在複合查找中才起作用,也就是說多條件查詢時起作用. (5).全文索引(innodb不支持全文索引): create fulltext index index_name on table_name(屬性名); 2.索引的查看: show create table table_name; show index from table_name; 3.索引的刪除: drop index index_name on table_name; 索引是不能直接更新的,只有通過先刪除再添加來模仿更新.通過mysql workbench中的索引操作可以詳細看出執行的語句,來加深理解.
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 當在Windows刪除文件時出現找不到該項目或者顯示該文件不在磁碟中,可以嘗試以下方法: 在要刪除文件的同級目錄下 新建一文本文檔,將下列代碼複製到文檔中,將文檔保存為尾碼名為.bat的文檔(名字隨意), DEL /F /A /Q \\?\%1 RD /S /Q \\?\%1 把你想刪除的文件或文件 ...
  • Linux系統擴容方法彙總 相信很多朋友都有過這樣的經歷,本想裝個Ubantu玩玩,沒想到玩久了反而不習慣Windows了,然而開始裝系統的時候只分配了非常小的空間,那應該怎樣擴展我們的ubantu呢?下麵我為大家總結幾種方法(僅在ubantu下測試過) 一、通過系統整體遷移 首先:進入Window ...
  • Cobbler(補鞋匠)是通過將DHCP、TFTP、DNS、HTTP等服務進行集成,創建一個中央管理節點,其可以實現的功能有配置服務,創建存儲庫,解壓縮操作系統媒介,代理或集成一個配置管理系統,控制電源管理等。 Cobbler的最終目的是實現無需進行人工干預即可安裝機器。 pxe概述 預啟動執行環境 ...
  • boot分區是系統啟動中最重要的部分,如果伺服器由於病毒攻擊又或者被管理員誤刪除了boot分區。那麼就會存在潛在的風險。為什麼說是潛在的風險?因為boot分區被刪除後系統仍在繼續運行,看似無狀況但是在執行關機操作後就會無法啟動。 大致步驟 恢復過程 1.首先查看系統的磁碟情況,根目錄在邏輯捲,boo ...
  • 在windows系統中個,每個進程擁有自己獨立的虛擬地址空間(Virtual Address Space)。這一地址空間的大小與電腦硬體、操作系統以及應用程式都有關係。 對於32位程式來說,最多能使用2GB空間(0x00010000-0x7FFEFFFF)。為了獲得3GB的地址空間,在不同的win ...
  • 1 文件{ ls -rtl # 按時間倒敘列出所有目錄和文件 ll -rt touch file # 創建空白文件 rm -rf 目錄名 # 不提示刪除非空目錄(-r:遞歸刪除 -f強制) dos2unix # windows文本轉linux文本 unix2dos # linux文本轉windows ...
  • 1. 結構 1.1 概述 Structured Streaming組件滑動視窗功能由三個參數決定其功能:視窗時間、滑動步長和觸發時間. 視窗時間:是指確定數據操作的長度; 滑動步長:是指視窗每次向前移動的時間長度; 觸發時間:是指Structured Streaming將數據寫入外部DataStre ...
  • Spark Struntured Streaming是Spark 2.1.0版本後新增加的流計算引擎,本博將通過幾篇博文詳細介紹這個框架。這篇是介紹Spark Structured Streaming的基本開發方法。以Spark 自帶的example進行測試和介紹,其為"StructuredNetw ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...