一、數據庫相關概念css
數據庫服務器(本質就是一臺計算機,該計算機之上安裝有數據庫管理軟件的服務端)html
數據庫管理系統RDBMS(本質就是一個C/S機構的套接字軟件)node
庫(文件夾)===》數據庫mysql
表(文件)redis
記錄:抽取一個事物的全部典型特徵/數據 ,說白了就是一條數據sql
eg:數據庫
egon,18,180,male,Truewindows
數據
name='egon' age=18 height=180 sex="male" beutiful=True緩存
二、數據庫管理系統 / 軟件分類:服務器
關係型:
有表結構,存取數居前一定先定義表結構,存數據必須按照字段的類型或者約束來
典型表明:MySQL、Orcale、DB二、SQL Server
非關係型:
存取數據都是採用 key : value 的形式
典型表明:Mongodb、redis、memcache
一、安裝
二、加環境變量
三、把mysqld軟件作成系統服務
注意:製做以前先把mysqld關掉
C:\Windows\system32>tasklist |findstr mysqld
mysqld.exe 8372 Console 2 454,916 K
C:\Windows\system32>taskkill /F /PID 8372
成功: 已終止 PID 爲 8372 的進程。
製做:
mysqld --install
查看:
windows+r
輸入services.msc
四、啓動:
未製做系統服務的啓動方式:
一、啓動服務端
mysqld
二、啓動客戶端
mysql -uroot -p -h127.0.0.1 -P 3306
若是是在本機登陸mysqld服務端能夠簡寫:
mysql -uroot -p
製做完系統服務後就能夠鼠標點擊啓動或關閉mysql:
windows+r
輸入services.msc
找到mysql,啓動或關閉
五、破解管理員密碼
一、先關閉mysqld服務端
二、以跳過受權表的方式在命令行中啓動mysqld服務端
mysqld --skip-grant-tables
三、客戶端直接以無密碼的方式登陸root用戶,修改密碼
mysql -uroot -p
mysql> update mysql.user set password=password("123") where user="root" and host="localhost";
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1 Changed: 0 Warnings: 0
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
四、在命令行中用taskkill殺死mysqld服務,而後正常啓動mysqld
taskkill /F /PID 131312
def password(mingwen):
import hashlib
m=hashlib.md5()
m.update(mimgwen)
return m.hexdigest()
六、統一字符編碼
一、在mysql安裝目錄下新建my.ini文件
二、修改my.ini
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
三、重啓mysqld
四、客戶端登陸,輸入\s查看結果
Windows平臺下在服務中添加MySQL
http://www.cnblogs.com/liuqz/p/8989552.html
一、庫(文件夾)
增: create database db1 charset utf8; 改: alter database db1 charset gbk; 查: 查看全部庫的名字: show database; 查看單獨一個庫的信息: show create database db1; 刪: drop database db1;
二、表(文件)
首先切換文件夾: use db1; select database(); #查看當前所在文件夾 增: create table t1 (id int, name char); 改: alter table t1 modify name char(16); 查: 查看當前庫下全部表名: show tables; 查看t1表的詳細信息: show create table t1; 查看錶結構: desc t1 ; #description 刪: drop t1
三、記錄(文件的一行內容)
增: insert into db1.t1 values (1,'egon'),(2,'alex'); 改: update db1.t1 set name='sb' where id>1; 查: select id,name from db1.t1; 刪: delete from db1.t1 where name='sb'
現實生活中咱們用來存儲數據的文件有不一樣的類型,每種文件類型對應各自不一樣的處理機制:好比處理文本用txt類型,處理表格用excel,處理圖片用png等
數據庫中的表也應該有不一樣的類型,表的類型不一樣,會對應mysql不一樣的存取機制,表類型又稱爲存儲引擎。
存儲引擎說白了就是如何存儲數據、如何爲存儲的數據創建索引和如何更新、查詢數據等技術的實現方法。由於在關係數據庫中數據的存儲是以表的形式存儲的,因此存儲引擎也能夠稱爲表類型(即存儲和操做此表的類型)
在Oracle 和SQL Server等數據庫中只有一種存儲引擎,全部數據存儲管理機制都是同樣的。而MySql數據庫提供了多種存儲引擎。用戶能夠根據不一樣的需求爲數據表選擇不一樣的存儲引擎,用戶也能夠根據
本身的須要編寫本身的存儲引擎SQL 解析器、SQL 優化器、緩衝池、存儲引擎等組件在每一個數據庫中都存在,但不是每 個數據庫都有這麼多存儲引擎。MySQL 的插件式存儲引擎可讓存儲引擎層的開發人員設 計他們但願的存儲層,例如,有的應用須要知足事務的要求,有的應用則不須要對事務有這 麼強的要求 ;有的但願數據能持久存儲,有的只但願放在內存中,臨時並快速地提供對數據 的查詢。
MariaDB [(none)]> show engines\G #查看全部支持的存儲引擎 MariaDB [(none)]> show variables like 'storage_engine%'; #查看正在使用的存儲引擎
MySQL存儲引擎介紹
#InnoDB 存儲引擎 支持事務,其設計目標主要面向聯機事務處理(OLTP)的應用。其 特色是行鎖設計、支持外鍵,並支持相似 Oracle 的非鎖定讀,即默認讀取操做不會產生鎖。 從 MySQL 5.5.8 版本開始是默認的存儲引擎。 InnoDB 存儲引擎將數據放在一個邏輯的表空間中,這個表空間就像黑盒同樣由 InnoDB 存儲引擎自身來管理。從 MySQL 4.1(包括 4.1)版本開始,能夠將每一個 InnoDB 存儲引擎的 表單獨存放到一個獨立的 ibd 文件中。此外,InnoDB 存儲引擎支持將裸設備(row disk)用 於創建其表空間。 InnoDB 經過使用多版本併發控制(MVCC)來得到高併發性,而且實現了 SQL 標準 的 4 種隔離級別,默認爲 REPEATABLE 級別,同時使用一種稱爲 netx-key locking 的策略來 避免幻讀(phantom)現象的產生。除此以外,InnoDB 存儲引擎還提供了插入緩衝(insert buffer)、二次寫(double write)、自適應哈希索引(adaptive hash index)、預讀(read ahead) 等高性能和高可用的功能。 對於表中數據的存儲,InnoDB 存儲引擎採用了彙集(clustered)的方式,每張表都是按 主鍵的順序進行存儲的,若是沒有顯式地在表定義時指定主鍵,InnoDB 存儲引擎會爲每一 行生成一個 6 字節的 ROWID,並以此做爲主鍵。 InnoDB 存儲引擎是 MySQL 數據庫最爲經常使用的一種引擎,Facebook、Google、Yahoo 等 公司的成功應用已經證實了 InnoDB 存儲引擎具有高可用性、高性能以及高可擴展性。對其 底層實現的掌握和理解也須要時間和技術的積累。若是想深刻了解 InnoDB 存儲引擎的工做 原理、實現和應用,能夠參考《MySQL 技術內幕:InnoDB 存儲引擎》一書。 #MyISAM 存儲引擎 不支持事務、表鎖設計、支持全文索引,主要面向一些 OLAP 數 據庫應用,在 MySQL 5.5.8 版本以前是默認的存儲引擎(除 Windows 版本外)。數據庫系統 與文件系統一個很大的不一樣在於對事務的支持,MyISAM 存儲引擎是不支持事務的。究其根 本,這也並不難理解。用戶在全部的應用中是否都須要事務呢?在數據倉庫中,若是沒有 ETL 這些操做,只是簡單地經過報表查詢還須要事務的支持嗎?此外,MyISAM 存儲引擎的 另外一個不同凡響的地方是,它的緩衝池只緩存(cache)索引文件,而不緩存數據文件,這與 大多數的數據庫都不相同。 #NDB 存儲引擎 年,MySQL AB 公司從 Sony Ericsson 公司收購了 NDB 存儲引擎。 NDB 存儲引擎是一個集羣存儲引擎,相似於 Oracle 的 RAC 集羣,不過與 Oracle RAC 的 share everything 結構不一樣的是,其結構是 share nothing 的集羣架構,所以能提供更高級別的 高可用性。NDB 存儲引擎的特色是數據所有放在內存中(從 5.1 版本開始,能夠將非索引數 據放在磁盤上),所以主鍵查找(primary key lookups)的速度極快,而且可以在線添加 NDB 數據存儲節點(data node)以便線性地提升數據庫性能。因而可知,NDB 存儲引擎是高可用、 高性能、高可擴展性的數據庫集羣系統,其面向的也是 OLTP 的數據庫應用類型。 #Memory 存儲引擎 正如其名,Memory 存儲引擎中的數據都存放在內存中,數據庫重 啓或發生崩潰,表中的數據都將消失。它很是適合於存儲 OLTP 數據庫應用中臨時數據的臨時表,也能夠做爲 OLAP 數據庫應用中數據倉庫的維度表。Memory 存儲引擎默認使用哈希 索引,而不是一般熟悉的 B+ 樹索引。 #Infobright 存儲引擎 第三方的存儲引擎。其特色是存儲是按照列而非行的,所以很是 適合 OLAP 的數據庫應用。其官方網站是 http://www.infobright.org/,上面有很多成功的數據 倉庫案例可供分析。 #NTSE 存儲引擎 網易公司開發的面向其內部使用的存儲引擎。目前的版本不支持事務, 但提供壓縮、行級緩存等特性,不久的未來會實現面向內存的事務支持。 #BLACKHOLE 黑洞存儲引擎,能夠應用於主備複製中的分發主庫。 MySQL 數據庫還有不少其餘存儲引擎,上述只是列舉了最爲經常使用的一些引擎。若是 你喜歡,徹底能夠編寫專屬於本身的引擎,這就是開源賦予咱們的能力,也是開源的魅 力所在。
方法1:建表時指定
MariaDB [db1]> create table innodb_t1(id int,name char)engine=innodb; MariaDB [db1]> create table innodb_t2(id int)engine=innodb; MariaDB [db1]> show create table innodb_t1; MariaDB [db1]> show create table innodb_t2;
方法2:在配置文件中指定默認的存儲引擎
/etc/my.cnf [mysqld] default-storage-engine=INNODB innodb_file_per_table=1
查看
[root@egon db1]# cd /var/lib/mysql/db1/ [root@egon db1]# ls db.opt innodb_t1.frm innodb_t1.ibd innodb_t2.frm innodb_t2.ibd