兩 個表中都包含部門編號,部門表中的部門編號應當存在唯一性約束,部門表中的部門編號和員工表中的部門編號存在一對多聯系。
成都網站建設、網站設計介紹好的網站是理念、設計和技術的結合。創新互聯擁有的網站設計理念、多方位的設計風格、經驗豐富的設計團隊。提供PC端+手機端網站建設,用營銷思維進行網站設計、采用先進技術開源代碼、注重用戶體驗與SEO基礎,將技術與創意整合到網站之中,以契合客戶的方式做到創意性的視覺化效果。
1.數據庫概述
簡而言之,數據庫(DataBase)就是一個存儲數據的倉庫。為了方便數據的存儲和管理,將數據按照特定的規律存儲在磁盤上。通過數據庫管理系統,可以有效的組織和管理存儲在數據庫中的數據。如今,已經存在的Oracle、SQLServer、MySQL等諸多優秀的數據庫。
詳解內容:
數據存儲方式
數據庫在開發中的作用
數據庫訪問技術
MySQL數據庫的介紹
數據庫泛型
SQL語言
常見數據庫系統
如果學習數據庫
1.1 數據庫理論基礎
數據庫能夠將數據按照特定的規律組織起來。那么,數據是如何存儲的、數據庫要遵守什么規則、數據庫在什么地方使用,這些都是首先要了解的問題。
1.1.1 數據存儲方式
如今數據庫已經無處不在了。
一個網站需要有數據庫來存儲數據。
一個學校需要用數據庫來存儲學生和教師的信息。
一個公司需要用數據庫來存儲員工的信息和公司的資料。
要學習數據庫,必須先了解數據庫是如何存儲數據的。
數據發展分為三個階段:
1. 人工管理階段
2. 文件系統階段
3. 數據庫系統階段
1.1.2 數據庫泛型
數據庫泛型就是數據庫應該遵循的規則。數據庫泛型也稱為范式。目前關系數據庫最常用的四種范式分別是:
第一范式(1NF)
第二范式(2NF)
第三范式(3NF)
BCN范式(BCNF)
在設計數據庫時,數據庫需要滿足的最低要求的范式是第一范式。第一范式的要求表中不能有重復字段,并且每個字段不能再拆分。如果有一個數據庫連第一范式都不滿足的話,那就不能稱之為關系型數據庫了。只有滿足了第一范式的要求,才可能在這個關系數據庫中創建表。
在滿足第一范式的基礎上,可以將數據庫中進行一步的細化。細化后可以使數據庫滿足第二范式的要求。依次進行細化,可以得到第三范式、BCN范式。
1.1.3 數據庫在開發中作用
現在大部分的管理系統和軟件都需要使用數據庫來存儲數據。在開發過程中,數據庫已經成為必不可少的一部分。本小節將為讀者簡單介紹一下數據庫在開發中的作用。
在軟件開發過程中,經常需要使用數據庫來存儲數據。比如,一個學校的學生管理系統就需要數據庫來存儲學生的學籍信息、考試信息、教師的信息、課程信息等。再比如,銀行的管理系統也需要數據庫來存儲信息。用戶的銀行帳戶、存款量、存款和取款的記錄等信息都是存儲在數據庫中的。當用戶向自己的帳戶里存款時,管理系統會在數據庫中更新該用戶的存款量。
1.2 數據庫系統
1.2.1 數據庫系統
很多讀者認為數據庫就是數據庫系統(DataBase System, 簡稱為DBS)。其實,數據庫系統的范圍比數據庫大很多。數據庫系統不是一個單純的數據庫,而是由數據庫、數據庫管理系統、應用開發工具構成。很多時候,數據庫管理員和用戶可以當成數據庫系統的一份子。
數據庫就是存儲數據的地方。
數據庫管理系統(DataBase Management System, 簡稱為DBMS)是用來定義數據、管理和維護數據的軟件。它是數據庫系統的一個重要組成部分。應用系統是需要使用數據庫的軟件。比如學員管理系統就是一個應用系統,這個應用系統需要數據庫管理它的數據。應用開發工具就是用來開發應用系統的。
1.2.2 SQL語言
SQL(Structured Query Language)語言的全稱是結構化查詢語言。數據庫管理系統通過SQL語言來管理數據庫中的數據。
SQL語言分為三個部分:
數據定義語言(Data Definition Language, 簡稱為DDL)
數據操作語言(Data Manipulation Language, 簡稱為DML)
數據控制語言(Data Control Language, 簡稱為DCL)
數據查詢語言(Data Query Language, 簡稱DQL)
1.2.3 數據庫訪問技術
應用程序中,程序語言需要使用數據庫訪問技術來訪問數據庫。只有使用了數據庫訪問技術,程序中嵌入的SQL語句才會起作用。不同程序語言訪問數據庫的方式是不一樣的。
JDBC是一種用于執行SQL語句的Java API。通過JDBC可以訪問多種關系數據庫。JDBC由一組用Java語言編寫的類和接口組成。使用JDBC時,必須要安裝驅動程序Connector/J。
PHP中為程序員提供了MySQL功能模塊,PHP5以后開始提供mysqli接口。PHP可以通過MySQL功能模塊和mysqli接口來訪問MySQL數據庫。
1.3 常見數據庫
1.3.1 常見數據庫系統
如今已經在很多優秀的商業數據庫
如甲骨文(Oracle)公司的Oracle數據庫
IBM公司的DB2數據庫
微軟公司的SQL Server數據庫和Access數據庫。
還有很多優秀的開源數據庫,如MySQL數據庫、PostgreSQL數據庫等。
1. 甲骨文的Oracle
2. IBM的DB2
3. 微軟的Access和SQL Server
4. 開源PostgreSQL
6. 開源MySQL
1.3.2 為什么要使用MySQL
如今很多大型網站已經選擇MySQL數據庫來存儲數據。那么,MySQL到底有什么優勢呢?MySQL數據庫的使用非常廣泛,尤其是在Web應用方面。由于MySQL數據庫發展勢頭迅猛,SUN公司于2008年收購了MySQL數據庫。這筆交易的收購價格高達10億美元。這中以說明MySQL數據庫價值。
MySQL數據庫的優勢:
1. 開源代碼
2. 跨平臺性
3. 價格優勢
4. 功能強大且使用方便
1.3.3 MySQL版本和獲取
MySQL數據庫可以在Windows、UNIX、Linux和Mac OS等操作系統上運行。因此,MySQL有不同操作系統的版本。而且,根據發布的先后順序,現在已經在開發MySQL的6.0版了。
根據MySQL的開發情況,可以將MySQL分為Alpha、Beta、Gamma和Generally Available(GA)等版本。
- Alpha(開發過程中)
- Beta(測試版)
- Gamma(比Beta版更高級)
- Generally Available(GA)(穩定版)
1.4 如果學習數據庫
數據庫已經成為軟件系統的一部分,那么學好數據庫將是軟件開發的一個必要條件。如何才能學好數據庫,這個問題沒有確切的答案。
學好數據庫的方法:
1. 多上機實踐
2. 多編寫SQL語句
3. 通過Java或PHP程序語言操作數據庫
4. 數據庫理論知識不能丟
1.5 常見問題及解答
1. 如何選擇數據庫?
2. 如何選擇MySQL版本?
1.6 本章習題
1. 數據存儲的發展過程經歷了哪幾個階段?
2. 常用數據庫系統有哪些?
3. MySQL數據庫如何分類?
2.Windows平臺下安裝與配置MySQL
在Windows系列的操作系統下,MySQL數據庫的安裝包分為圖形化界面安裝和免安裝(noinstall)這兩種安裝包。這兩種安裝包的安裝方式不同,而且配置方式也不同。圖形化界面安裝包有完整的安裝向導,安裝和配置很方便。免安裝的安裝包直接解壓即可使用,但是配置起來很不方便。
安裝MySQL數據庫
配置MySQL數據庫
常用圖形管理工具介紹
配置和使用免安裝的MySQL數據庫
2.1 安裝與配置MySQL
2.1.1 安裝MySQL
MySQL圖形化安裝包有一個完整的安裝向導,根據安裝向導可以很方便的安裝MySQL數據庫。在Windows操作系統下,有兩種MySQL圖形化安裝包。這兩種安裝包分別是"Windows Essentials"和"Windows MSI Installer"。前者包含了MySQL中最主要和最常用的功能,但是不包含一些不常用的功能。后者包含了MySQL全部功能,包括不常用的功能。
選擇Microsoft Windows選項
mysql-5.1.40-win32.msi(圖形界面安裝)
mysql-essential-5.1.40-win32.msi (圖形界面安裝)
mysql-noinstall-5.1.40-wind32.zip (免安裝)
安裝步驟:
1. Next
2. Typical Complete Custom(O)
3. MySQL Server
Client Programs
C Includes Files / Lib Files(X)
Change: ?????
4. Install
Setup Type: Custom
Destination Folder(程序安裝路徑):
Data Folder(數據存儲的路徑):
5. Next-Next-
(O)Configure the MySQL Serer now
(O)Register the MySQL Server now
6. Finish
2.1.2 配置MySQL
安裝完成時,選上了Configure the MySQL Server now選項,圖形化安裝向導將進入MySQL配置歡迎界面。通過配置向導,可以設置MySQL數據庫的各種參數。
1. Next
2. (O)Detailed Configuration
(X)Standard Configuration
3. (O)Developer Machine(開發者)
Server Machine(服務器)
Dedicated MySQL Server Machine(專用的數據庫服務器)
4. (O)Multifunctional Database(多功能型數據庫)
Transactional Database Only(事務型的數據庫, InnoDB)
Non-Transactional Database Only(只支持MyISaM類型數據庫,非事務)
5. InnoDB Tablespace Settings (配置表空間)
6. 設置服務器的連接數
Decision Support(DSS) / OLAP
Online Transaction Processing(OLTP)
(O)Manual Setting
Concurrent Connections: 10
7. MySQL服務的端口號:
(O)Add firewall exception for this port(允許防火墻)
(X)Enable Strict Mode(是區分大寫)
8. 設置字符集
Standard Character Set
Best Support for Multilingualism
(O)Manual Selected Default Character Set / Collation
utf-8
9. Install As Windws Service 服務選項
Service Name: MySQL
(O)Lanch the MySQL Server automatically(服務是否自動啟動)
(O)Include Bin Directory in Windows PATH(添加到path路徑當中)
10. Modify Security Setting:
New root password:
confirm:
(X)Enable root access from remote machines(不否遠程訪問root)
11. Execute
12. Finish
2.2 啟動服務并登錄MySQL數據庫
MySQL數據庫分為服務器端(Server)和客戶端(Client)兩部分。只有服務器端的服務開戶以后,才可以通過客戶端來登錄到MySQL數據庫。
2.2.1 啟動MySQL服務
開始-設置-控制面板-管理工具-服務
2.2.2 登錄MySQL服務器
1. 開始-運行-cmd
mysql -h localhost -u root -p
mysql
2. 開始-運行-mysql -h 127.0.0.1 -u root -p
2.2.3 配置path變量
如果MySQL的應用程序的目錄沒有添加到Windows系統的path環境變量中,可以手工的將MySQL的目錄添加到path中。
將MySQL的應用程序的目錄添加到Windows系統的path環境變量中,可以使以后的操作更加方便。例如,可以直接從運行對話框輸入MySQL數據庫命令。而且,以后在編程時也會更加方便。配置path路徑很簡單,只要將MySQL的應用程序的目錄添加到系統的path環境變量中就可以了。
1. 右擊【我的電腦】-【屬性】
2. 在系統環境變量中選中path變量,然后單擊編輯按鈕進入編輯環境變量的對話框。
3. 把MySQL應用程序的目錄添加到path環境變量名值的后面。已經存在的目錄用分號隔開。
2.3 更改MySQL的配置
MySQL數據庫安裝好了以后,可能根據實際情況更改MySQL的某些配置。一般可以通過兩種方式來更改。一種是通過配置向導來更改配置,另一種是手工來更改配置。
需要用的資料以鏈接的形式給需要的同學。
我用的mysql版本為: Mysql-5.5.45-win64.msi 密碼是:26zw
圖形化工具 Navicat(前期不推薦用,直接手動敲): Navicat 密碼:c7fs
開始我的MySQL之旅吧 始于2016.12.04
--WH
一、數據庫的安裝
這個就不在這里過多闡述了,因為網上實在是太多安裝mysql的教程了,有了我給的mysql,在按照這個安裝教程(MySQL安裝教程)去看,就能夠安裝完好。
安裝好mysql后,如果需要使用windows命令窗口(也就是cmd)來操作mysql,那么就需要配置環境變量,在安裝好的mysql下找到bin,將其目錄放到環境變量path中去,就行了,檢測成功與否的方法是在cmd命令窗口中輸入mysql,就會出現一大段英文,就說明成功了,反之失敗,如果不會的話就去百度搜教程。
二、數據庫的基本操作
1、開啟mysql服務命令
net start mysql
2、進入mysql的兩種方式
明文進入:mysql -uroot -proot格式:mysql -u帳號 -p密碼
密文進入:mysql -uroot -p 按enter會提示你輸入密碼(Enter pssword:),此時你寫的密碼就會顯示為***這樣。
3、查看mysql中所有的數據庫(一般在固定的單詞命令就會是用大寫,這個要習慣,看多了敲多了就認識了)
前面四個數據庫是mysql中自帶的,也就是必須的.
SHOW DATABASES;
4、創建名為test_1的數據庫
格式:CREATE DATABASE 數據庫名
CREATE DATABASE test_1;
5、刪除名為test_1的數據庫
格式:DROP DATABASE 數據庫名
DROP DATABASE test_1;
總結:學習了對數據庫的三個操作,1、查看所有數據庫 2、創建數據庫 3、刪除數據庫
三、數據表的基本操作
數據表和數據庫還有Mysql三者的關系
mysql中保存了很多數據庫、一個數據庫中可以保存很多表。
對數據表的增(創建表)刪(刪除表)改(修改表字段)查(查詢表結構)。 注意:這里的操作對象是表,對表的操作也就是表的結構,和表中的字段的操作(字段和記錄要分清楚)
前提:表是在數據庫下的,所以要先確實使用哪個數據庫。
USE test_1;
1、創建數據表
格式:CREATE TABLE 數據表名(
字段名1數據類型[列級別約束條件],
字段名2數據類型[列級別約束條件],
字段名3數據類型[列級別約束條件]
);
注意:格式不一定需要這樣隔著寫,完全可以全部寫成一行。但是那樣寫可觀性非常差。我這樣寫只是為了可以看的更清晰。
解釋:
1、[]中括號中的內容表示可以有可以沒有,
2、列級別這個“列”一定要搞清楚說的是什么,一張表中有行有列,列表示豎,行表示橫
3、約束條件后面會講到
1.1、創建沒有約束的student表
CREATE TABLE student( idINT(11), nameVARCHAR(12), ageINT(11) );
注釋:SHOW TABLES 查詢數據庫底下的所有表。
1.2、創建有約束的student表
六大約束:主鍵約束、外鍵約束、非空約束、唯一約束、默認約束、自動增加
1.2.1:主鍵約束
PRIMARY KEY(primary key):獨一無二(唯一)和不能為空(非空),通俗的講,就是在表中增加記錄時,在該字段下的數據不能重復,不能為空,比如以上面創建的表為例子,在表中增加兩條記錄,如果id字段用了主鍵約束。則id不能一樣,并且不能為空。一般每張表中度有一個字段為主鍵,唯一標識這條記錄。以后需要找到該條記錄也可以同這個主鍵來確認記錄,因為主鍵是唯一的,并且非空,一張表中每個記錄的主鍵度不一樣,所以根據主鍵也就能找到對應的記錄。而不是多條重復的記錄。如果沒有主鍵,那么表中就會存在很多重復的記錄,那么即浪費存儲空間,在查詢時也消耗更多資源。
一般被主鍵約束了的字段度習慣性的稱該字段為該表的主鍵
單字段主鍵約束
兩種方式都可以
CREATE TABLE student(CREATE TABLE student(
idINT(11) PRIMARY KEY,idINT(11),
nameVARCHAR(12),nameVARCHAR(12),
ageINT(11) ageINT(11),
); PRIMARY KEY(id) );
多字段主鍵約束(復合主鍵)
這個id和name都市主鍵,說明在以后增加的插入的記錄中,id和name不能同時一樣,比如說可以是這樣。一條記錄為id=1,name=yyy、另一條記錄為:id=1,name=zzz。 這樣是可以的。并不是你們所理解的兩個字段分別度不可以相同。
CREATE TABLE student(CREATE TABLE student(
idINT(11) PRIMARY KEY,idINT(11),
nameVARCHAR(12) PRIMARY KEY, nameVARCHAR(12),
ageINT(11) ageINT(11),
);PRIMARY KEY(id,name) );
1.2.2:外鍵約束
什么是外鍵舉個例子就清楚了,有兩張表,一張表是emp(員工)表,另一張表是dept(部門)表,一個員工屬于一個部門,那么如何通過員工能讓我們自己他在哪個部門呢?那就只能在員工表中增加一個字段,能代表員工所在的部門,那該字段就只能是存儲dept中的主鍵了(因為主鍵是唯一的,才能確實是哪個部門,進而代表員工所在的部門,如果是部門名稱,有些部門的名稱可能是同名。就不能區分了。),像這樣的字段,就符合外鍵的特點,就可以使用外鍵約束,使該字段只能夠存儲另一張表的主鍵。如果不被外鍵約束,那么該字段就無法保證存儲進來的值就一定是另一張表的主鍵值。
外鍵約束的特點:
1、外鍵約束可以描述任意一個字段(包括主鍵),可以為空,并且一個表中可以有多個外鍵。但是外鍵字段中的值必須是另一張表中的主鍵。
2、這樣被外鍵關聯的兩種表的關系可以稱為父子表或者主從表。子表(從表)擁有外鍵字段的表,父表(主表)被外鍵字段所指向的表。
3、子表被外鍵約束修飾的字段必須和父表的主鍵字段的類型一樣。
注意:一個表中有被外鍵修飾的字段,就稱該表有外鍵(是“有外鍵”。而不是“是外鍵”),并會給該表中的外鍵約束取一個名稱,所以我們常說的這個表有沒有外鍵,指的不是被外鍵約束修飾的字段名,而是指這個表是否有存在外鍵約束。也就是說,不能說這個表的外鍵是xxx(該表中被外鍵約束修飾的字段名),這種說法是錯誤的,但是大多數人已經習慣了這樣,雖然影響不大,但是在很多時候需要理解一個東西時,會造成一定的困擾。
格式:CONSTRAINT外鍵名稱FOREIGN KEY(被外鍵約束的字段名稱)REFERENCES 主表名(主鍵字段)
英文解釋:CONSTRAINT:約束REFERENCES:參考
CREATE TABLE tableA
(
id INT(11),
name VARCHAR(22),
location VARCHAR(50),
PRIMARY KEY(id)
);
CREATE TABLE tableB
(
id INT(11),
name VARCHAR(22) NOT NULL,
deptId INT(11),
PRIMARY KEY(id),
CONSTRAINT tableA_tableB_1 FOREIGH KEY(deptId) REFERENCES tableA(id)
);
解釋:tableB中有一個名為tableA_tableB_1的外鍵關聯了tableA和tableB兩個表,被外鍵約束修飾的字段為tableB中的deptId,主鍵字段為tableA中的id
1.2.3:非空約束
NOT NULL. 被該約束修飾了的字段,就不能為空,主鍵約束中就包括了這個約束
CREATE TABLE tableA
(
id INT(11),
name VARCHAR(22) NOT NULL,
location VARCHAR(50),
PRIMARY KEY(id)
);
1.2.4:唯一約束
UNIQUE 被唯一約束修飾了的字段,表示該字段中的值唯一,不能有相同的值,通俗點講,就好比插入兩條記錄,這兩條記錄中處于該字段的值不能是一樣的。
CREATE TABLE tableA
(
id INT(11),
name VARCHAR(22) UNIQUE,
location VARCHAR(50),
PRIMARY KEY(id)
);
也就是說在插入的記錄中,每條記錄的name值不能是一樣的。
1.2.5:默認約束
Default 指定這一列的默認值為多少,比如,男性同學比較多,性別就可以設置為默認男,如果插入一行記錄時,性別沒有填,那么就默認加上男
CREATE TABLE table
(
id INT(11) PRIMARY KEY,
name VARCHAR(22) NOT NULL,
deptId INT(11) DEFAULT 1111,
salary FLOAT
);
1.2.6:自動增加
AUTO_INCREMENT 一個表只能一個字段使用AUTO_INCREMENT,并且使用這個約束的字段只能是整數類型(任意的整數類型 TINYINT,SMALLIN,INT,BIGINT),默認值是1,也就是說從1開始增加的。一般就是給主鍵使用的,自動增加,使每個主鍵的值度不一樣,并且不用我們自己管理,讓主鍵自己自動生成
CREATE TABLE table ( id INT(11) PRIMARY KEY AUTO_INCREMENT, name VARCHAR(22) NOT NULL );
2、查詢表結構
2.1、查看表基本結構語句
格式1:DESCRIBE 表名/DESC 表名這兩個的功能是一樣的,簡寫了單詞describe
DESCRIBE student;
2.2、查看創建表的語句
格式:SHOW CREATE TABLE 表名
SHOW CREATE TABLE student;
這樣顯示的格式很不好,看不清楚,所以有了下面這個語句
格式:SHOW CREATE TABLE 表名\G
SHOW CREATE TABLE student\G;
3、修改數據表
修改數據表包括:對表中字段的增加、刪除、修改。 在這個里面用的關鍵字為 ALTER
3.1、修改表名
格式:ALTER TABLE舊表名 RENAME[TO]新表名;
將student表名改為student1(改完后在改回來)
ALTER TABLE student RENAME TO student1;
3.2、修改表中的字段名
格式:ALTER TABLE表名 CHANGE舊字段名新字段名新數據類型
將student表中的name字段名改為 username
ALTER TABLE student CHANGE name username VARCHAR(30);
3.3、修改表中的數據類型
格式:ALTER TABLE表名 MODIFY字段名數據類型
ALTER TABLE student MODIFY username VARCHAR(20);
解釋:只能修改字段名的數據類型,但是其原理跟上面change做的事情一樣,這里也有修改字段名的過程,只不過修改后的字段名和修改前的字段名相同,但是數據類型不一樣。
3.4、修改字段的排列位置
方式1:ALTER TABLE表名 MODIFY字段1數據類型 FIRST|AFTER字段2
解釋:將字段1的位置放到第一,或者放到指定字段2的后面
ALTER TABLE student MODIFY username VARCHAR(20) AFTER age;
方式2:ALTER TABLE表名 CHANGE字段1字段2數據類型 FIRST|AFTER字段3
解釋:其實是一樣的,將是字段2覆蓋字段1,然后在進行排序
ALTER TABLE student CHANGE username username VARCHAR(20) AFTER age;
總結
CHANGE和MODIFY的區別?
原理都市一樣的,MODIFY只能修改數據類型,但是CHANGE能夠修改數據類型和字段名,也就是說MODIFY是CHANGE的更具體化的一個操作。可能覺得用CHANGE只改變一個數據類型不太爽,就增加了一個能直接改數據類型的使用關鍵字MODIFY來操作。
3.5、添加字段
格式:ALTER TABLE表名稱 ADD新字段名數據類型[約束條件][FIRST|AFTER已存在的表名]
解釋:在一個特定位置增加一個新的字段,如果不指定位置,默認是最后一個。
ALTER TABLE student ADD sex VARCHAR(11);
3.6、刪除字段
格式:ALTER TABLE表名稱 DROP字段名;
ALTER TABLE student DROP sex;
3.7、刪除表的外鍵約束
格式:ALTER TABLE表名稱 DROP FOREIGN KEY外鍵約束名
注意:外鍵約束名 指的不是被外鍵約束修飾的字段名,切記,而是我們在創建外鍵約束關系時取的名字。
3.8、更改表的存儲引擎
格式:ALTER TABLE表名 ENGINE=更改后的存儲引擎名
這個存儲引擎目前我自己也不太清楚,雖然知道有哪幾種引擎,但是稍微深入一點就不清楚了,所以打算留到日后在說。
4、刪除表
4.1、刪除無關聯表
格式:DROP TABLE表名;
ALTER TABLE student;
4.2、刪除被其他表關聯的主表
這個是比較重要的一點,在有外鍵關聯關系的兩張表中,如果刪除主表,那么是刪不掉的,并且會報錯。因為有張表依賴于他。那怎么辦呢?針對這種情況,總共有兩種方法
1、先刪除你子表,然后在刪除父表,這樣就達到了刪除父表的目的,但是子表也要被刪除
2、先解除外鍵關系,然后在刪除父表,這樣也能達到目的,并且保留了子表,只刪除我們不需要的父表。在3.7中就講解了如何刪除外鍵關系。
如果你已經轉了有服務器端程序,而且不想在dos下搞,那就裝個mysql客戶端程序。操作的時候和sqlserver類似。
如果你非要在dos下搞。
1.運行dos,輸入裝mysql服務器所在目錄,如G:\MySQL Server 5.0\bin。
2.輸入命令mysql -uroot -p。-u指用戶名,root是用戶名。-p是密碼。
完了他會讓你輸入密碼,照做。
3.進去后(出現welcome表示成功),命令use yourtable
4.執行你的創建語句。語句結束要寫分號。
5.來百度給分。
1、使用 create table 語句可完成對表的創建, create table 的創建形式:
create table 表名稱(列聲明);
以創建 people 表為例, 表中將存放 學號(id)、姓名(name)、性別(sex)、年齡(age) 這些內容:
create table people(
id int unsigned not null auto_increment primary key,
name char(8) not null,
sex char(4) not null,
age tinyint unsigned not null
);
其中,auto_increment就可以使Int類型的id字段每次自增1。
2、向表中插入數據使用insert 語句。
insert 語句可以用來將一行或多行數據插到數據庫表中, 使用的一般形式如下:
insert [into] 表名 [(列名1, 列名2, 列名3, ...)] values (值1, 值2, 值3, ...);
其中 [] 內的內容是可選的, 例如, 要給上步中創建的people 表插入一條記錄, 執行語句:
insert into people(name,sex,age) values( "張三", "男", 21 );
3、想要查詢是否插入成功,可以通過select 查詢語句。形式如下:
select * from people;
擴展資料:
當mysql大批量插入數據的時候使用insert into就會變的非常慢,?mysql提高insert into 插入速度的方法有三種:
1、第一種插入提速方法:
如果數據庫中的數據已經很多(幾百萬條), 那么可以?加大mysql配置中的 bulk_insert_buffer_size,這個參數默認為8M
舉例:bulk_insert_buffer_size=100M;
2、第二種mysql插入提速方法:
改寫所有 insert into 語句為?insert?delayed into
這個insert delayed不同之處在于:立即返回結果,后臺進行處理插入。
3、第三個方法: 一次插入多條數據:
insert中插入多條數據,舉例:
insert into table values('11','11'),('22','22'),('33','33')...;
MySQL 提供了多種創建索引的方法:
1) 使用 CREATE INDEX 語句
可以使用專門用于創建索引的 CREATE INDEX 語句在一個已有的表上創建索引,但該語句不能創建主鍵。
語法格式:
CREATE 索引名 ON 表名 (列名 [長度] [ ASC | DESC])
語法說明如下:
索引名:指定索引名。一個表可以創建多個索引,但每個索引在該表中的名稱是唯一的。
表名:指定要創建索引的表名。
列名:指定要創建索引的列名。通常可以考慮將查詢語句中在 JOIN 子句和 WHERE 子句里經常出現的列作為索引列。
長度:可選項。指定使用列前的 length 個字符來創建索引。使用列的一部分創建索引有利于減小索引文件的大小,節省索引列所占的空間。在某些情況下,只能對列的前綴進行索引。索引列的長度有一個最大上限 255 個字節(MyISAM 和 InnoDB 表的最大上限為 1000 個字節),如果索引列的長度超過了這個上限,就只能用列的前綴進行索引。另外,BLOB 或 TEXT 類型的列也必須使用前綴索引。
ASC|DESC:可選項。ASC指定索引按照升序來排列,DESC指定索引按照降序來排列,默認為ASC。
2) 使用 CREATE TABLE 語句
索引也可以在創建表(CREATE TABLE)的同時創建。在 CREATE TABLE 語句中添加以下語句。語法格式:
CONSTRAINT PRIMARY KEY [索引類型] (列名,…)
在 CREATE TABLE 語句中添加此語句,表示在創建新表的同時創建該表的主鍵。
語法格式:
KEY | INDEX [索引名] [索引類型] (列名,…)
在 CREATE TABLE 語句中添加此語句,表示在創建新表的同時創建該表的索引。
語法格式:
UNIQUE [ INDEX | KEY] [索引名] [索引類型] (列名,…)
在 CREATE TABLE 語句中添加此語句,表示在創建新表的同時創建該表的唯一性索引。
語法格式:
FOREIGN KEY 索引名 列名
在 CREATE TABLE 語句中添加此語句,表示在創建新表的同時創建該表的外鍵。
在使用 CREATE TABLE 語句定義列選項的時候,可以通過直接在某個列定義后面添加 PRIMARY KEY 的方式創建主鍵。而當主鍵是由多個列組成的多列索引時,則不能使用這種方法,只能用在語句的最后加上一個 PRIMARY KRY(列名,…) 子句的方式來實現。
網站題目:mysql怎么建立員工表,mysql創建一張員工表
網頁鏈接:http://vcdvsql.cn/article6/hsedig.html
成都網站建設公司_創新互聯,為您提供Google、App開發、搜索引擎優化、網頁設計公司、網站制作、手機網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯