Mysql資料庫初識

来源:https://www.cnblogs.com/an-wen/archive/2019/06/19/11052315.html
-Advertisement-
Play Games

認識資料庫 1 什麼是數據(Data) 描述事物的符號記錄稱為數據,描述事物的符號既可以是數字,也可以是文字、圖片,圖像、聲音、語言等,數據由多種表現形式,它們都可以經過數字化後存入電腦 在電腦中描述一個事物,就需要抽取這一事物的典型特征,組成一條記錄,就相當於文件里的一行內容,如: 單純的一條 ...


認識資料庫

1 什麼是數據(Data)

描述事物的符號記錄稱為數據,描述事物的符號既可以是數字,也可以是文字、圖片,圖像、聲音、語言等,數據由多種表現形式,它們都可以經過數字化後存入電腦

在電腦中描述一個事物,就需要抽取這一事物的典型特征,組成一條記錄,就相當於文件里的一行內容,如:

1 安文,男,23,1995,山西

單純的一條記錄並沒有任何意義,如果我們按逗號作為分隔,依次定義各個欄位的意思,相當於定義表的標題

id,name,sex,age,birth,born_addr# 欄位/列名
1 安文,男,23,1995,山西 # 數據

這樣我們就可以瞭解alex,性別不詳,年齡83歲,出生於1935年,住的養老院是 老男孩

2 什麼是資料庫(DataBase,簡稱DB)

資料庫即存放數據的倉庫,只不過這個倉庫是在電腦存儲設備上,而且數據是按一定的格式存放的

過去人們將數據存放在文件櫃里,現在數據量龐大,已經不再適用

資料庫是長期存放在電腦內、有組織、可共用的數據集合。

資料庫中的數據按一定的數據模型組織、描述和儲存,具有較小的冗餘度、較高的數據獨立性和易擴展性,並可為各種 用戶共用

3 什麼是資料庫管理系統(DataBase Management System 簡稱DBMS)

在瞭解了Data與DB的概念後,如何科學地組織和存儲數據,如何高效獲取和維護數據成了關鍵

這就用到了一個系統軟體---資料庫管理系統

如MySQL、Oracle、SQLite、Access、MS SQL Server

mysql主要用於大型門戶,例如搜狗、新浪等,它主要的優勢就是開放源代碼,因為開放源代碼這個資料庫是免費的,他現在是甲骨文公司的產品。
oracle主要用於銀行、鐵路、飛機場等。該資料庫功能強大,軟體費用高。也是甲骨文公司的產品。
sql server是微軟公司的產品,主要應用於大中型企業,如聯想、方正等。

資料庫管理員 DBA(Database Administrator)

4 資料庫伺服器、數據管理系統、資料庫、表與記錄的關係(重點)

記錄:1 朱葛 13234567890 22(多個欄位的信息組成一條記錄,即文件中的一行內容)

表:userinfo,studentinfo,courseinfo(即文件)

資料庫:db(即文件夾)

資料庫管理系統:如mysql(是一個軟體)

資料庫伺服器:一臺電腦(對記憶體要求比較高)

總結:

資料庫伺服器-:運行資料庫管理軟體

資料庫管理軟體:管理-資料庫

資料庫:即文件夾,用來組織文件/表

表:即文件,用來存放多行內容/多條記錄

5 資料庫管理技術的發展歷程(瞭解)

一 人工管理階段

20世紀50年代中期以前,電腦主要用於科學計算。

當時的硬體水平:外存只有紙帶、卡片、磁帶,沒有磁碟等直接存取的存儲設備

當時的軟體狀況:沒有操作系統,沒有管理數據的軟體,數據的處理方式是批處理。

人工管理數據具有以下特點:

1 數據不保存:電腦主要用於科學計算,數據臨時用,臨時輸入,不保存

2 應用程式管理數據:數據要有應用程式自己管理,應用程式需要處理數據的邏輯+物理結構,開發負擔很重

3 數據不共用:一組數據只對應一個程式,多個程式之間涉及相同數據時,必須各自定義,造成數據大量冗餘

4 數據不具有獨立性:數據的邏輯結構或物理結構發生變化後,必須對應用程式做出相應的修改,開發負擔進一步加大

初識MYSQL

mysql瞭解

資料庫管理軟體分類

  管理數據的工具有很多種,不止mysql一個。關於分類其實可以從各個緯度來進行劃分,但是我們最常使用的分類還是根據他們存取數據的特點來劃分的,主要分為關係型和非關係型。

  可以簡單的理解為,關係型資料庫需要有表結構非關係型資料庫是key-value存儲的,沒有表結構

關係型:如sqllite,db2,oracle,access,sql server,MySQL,註意:sql語句通用
非關係型:mongodb,redis,memcache

mysql

  MySQL是一個關係型資料庫管理系統,由瑞典MySQL AB 公司開發,目前屬於 Oracle 旗下產品。MySQL 是最流行的關係型資料庫管理系統之一,在 WEB 應用方面,MySQL是最好的 RDBMS (Relational Database Management System,關係資料庫管理系統) 應用軟體。

  MySQL是一種關係資料庫管理系統,關係資料庫將數據保存在不同的表中,而不是將所有數據放在一個大倉庫內,這樣就增加了速度並提高了靈活性。

  MySQL所使用的 SQL 語言是用於訪問資料庫的最常用標準化語言。MySQL 軟體採用了雙授權政策,分為社區版和商業版,由於其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點,一般中小型網站的開發都選擇 MySQL 作為網站資料庫。

初識sql語句

  

#進入mysql客戶端
$mysql
mysql> select user();  #查看當前用戶
mysql> exit     # 也可以用\q quit退出

# 預設用戶登陸之後並沒有實際操作的許可權
# 需要使用管理員root用戶登陸
$ mysql -uroot -p   # mysql5.6預設是沒有密碼的
#遇到password直接按回車鍵
mysql> set password = password('root'); # 給當前資料庫設置密碼

# 創建賬號
mysql> create user 'eva'@'192.168.10.%'   IDENTIFIED BY '123';# 指示網段
mysql> create user 'eva'@'192.168.10.5'   # 指示某機器可以連接
mysql> create user 'eva'@'%'                    #指示所有機器都可以連接  
mysql> show grants for 'eva'@'192.168.10.5';查看某個用戶的許可權 
# 遠程登陸
$ mysql -uroot -p123 -h 192.168.10.3

# 給賬號授權
mysql> grant all on *.* to 'eva'@'%';
mysql> flush privileges;    # 刷新使授權立即生效

# 創建賬號並授權
mysql> grant all on *.* to 'eva'@'%' identified by '123' 

SQL : 結構化查詢語言(Structured Query Language)簡稱SQL(發音:/ˈes kjuː ˈel/ "S-Q-L"),是一種特殊目的的編程語言,是一種資料庫查詢和程式設計語言,用於存取數據以及查詢、更新和管理關係資料庫系統

  SQL語言主要用於存取數據、查詢數據、更新數據和管理關係資料庫系統,SQL語言由IBM開發。SQL語言分為3種類型:

  1、DDL語句 資料庫定義語言: 資料庫、表、視圖、索引、存儲過程,例如CREATE DROP ALTER

  2、DML語句 資料庫操縱語言: 插入數據INSERT、刪除數據DELETE、更新數據UPDATE、查詢數據SELECT

  3、DCL語句 資料庫控制語言: 例如控制用戶的訪問許可權GRANT、REVOKE

1. 操作文件夾(庫)
   增:create database db1 charset utf8;
   查:show databases;
   改:alter database db1 charset latin1;
   刪除: drop database db1;


2. 操作文件(表)
   先切換到文件夾下:use db1
   增:create table t1(id int,name char);
   查:show tables;
   改:alter table t1 modify name char(3);
      alter table t1 change name name1 char(2);
   刪:drop table t1;
    

3. 操作文件中的內容(記錄)
   增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');
   查:select * from t1;
   改:update t1 set name='sb' where id=2;
   刪:delete from t1 where id=1;

   清空表:
       delete from t1; #如果有自增id,新增的數據,仍然是以刪除前的最後一樣作為起始。
       truncate table t1;數據量大,刪除速度比上一條快,且直接從零開始,

*auto_increment 表示:自增
*primary key 表示:約束(不能重覆且不能為空);加速查找

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 開發同事反饋一個SQL Server存儲過程執行的時候,報“鏈接伺服器"(null)"的 OLE DB 訪問介面 "SQLNCLI10" 返回了消息 "Cannot start more transactions on this session."。這個存儲過程,個人做了一個精簡和脫敏處理後如下: ... ...
  • 大數據時代,給想從事IT的人帶來了新的發展機會,也提供了新的職業發展通道。在面對眾多的大數據就業崗位,我們應該選擇什麼樣的職業發展方向,並去學習相應技能達到企業要求呢? ...
  • Oracle 伺服器主要又實例、資料庫、程式全局區和前臺進程組成。 實例可以進一步劃分為系統全局區(SGA)和後臺進程(PMON、SMON等)兩部分,其中,SGA 使用操作系統的記憶體資源,而後臺進程需要使用 CPU 與記憶體資源。資料庫(Database)中包含數據文件(Data files)、控制文 ...
  • 題目 編寫一個 SQL 查詢,獲取 表中第二高的薪水(Salary) 。 例如上述 表,SQL查詢應該返回 作為第二高的薪水。如果不存在第二高的薪水,那麼查詢應返回 。 解決方案 方法一 :使用 和 子句 將不同的薪資按降序排序,然後使用 子句獲得第二高的薪資。 然而,如果沒有這樣的第二最高工資,這 ...
  • 字典 字典又稱為符號表、關聯數組或映射(map),是一種用於保存鍵值對(key value)的數據結構。 那麼 C 語言中有沒有這樣 key value 型的內置數據結構呢? 答案:沒有。 說起鍵值對,是不是想到了 Java 中的 Map?Java中的 Map 實現有兩個:HashMap 和 Tre ...
  • 查詢外鍵欄位信息SET pagesize 1000COL 外鍵擁有者 FOR A20COL 外鍵表 FOR A30COL 外鍵列 FOR A20COL 主鍵擁有者 FOR A20COL 主鍵表 FOR A30COL 主鍵列 FOR A20COL 外鍵名 FOR A30COL 主鍵名 FOR A30 ...
  • 1.查看虛擬機的預設網關和子網掩碼 a.vm菜單欄點擊編輯->虛擬網路編輯器 b.選擇VMnet8,點擊NAT設置,查看子網掩碼、網關IP 2. 修改伺服器的網路配置 a. 修改主機名 hostnamectl set-hostname node01(可選) b. 編輯網卡配置 vi /etc/sys ...
  • 1.-- 查看表結構 DESC 表名; 主要是欄位類型,主鍵,是否允許為空等。 2. 查看表中欄位的結構信息 可以用來查看表中欄位的註釋等,比如 select table_name,column_name,column_comment from information_schema.columns ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...