“mysql用的那個(gè)黑色的窗口”-- 汗,你用的是CMD來弄的???
南縣網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
右鍵點(diǎn)擊任務(wù)欄里面的CMD的那個(gè),【任務(wù)欄→CMD→屬性→字體】就可以設(shè)置了。
處理數(shù)據(jù)時(shí),遇到了需要將一行數(shù)據(jù)變成多行數(shù)據(jù)的情況
如下圖數(shù)據(jù)
需要將數(shù)據(jù)處理成
在這里我們需要用到mysql函數(shù)SUBSTRING_INDEX和mysql表mysql.help_topic
substring_index(str,delim,count)
通過如下語句,則可實(shí)現(xiàn)一行轉(zhuǎn)多行,最終實(shí)現(xiàn)上圖的效果
請注意轉(zhuǎn)換數(shù)據(jù)庫語言,再進(jìn)行試驗(yàn)。
/*
普通行列轉(zhuǎn)換
假設(shè)有張學(xué)生成績表(tb)如下:
Name Subject Result
張三 語文74
張三 數(shù)學(xué)83
張三 物理93
李四 語文74
李四 數(shù)學(xué)84
李四 物理94
*/
-------------------------------------------------------------------------
/*
想變成
姓名 語文 數(shù)學(xué) 物理
---------- ----------- ----------- -----------
李四 74 84 94
張三 74 83 93
*/
create table tb
(
[Name] varchar(10) ,
Subject varchar(10) ,
Result int
)
insert into tb(Name , Subject , Result) values('張三' , '語文' , 74)
insert into tb(Name , Subject , Result) values('張三' , '數(shù)學(xué)' , 83)
insert into tb(Name , Subject , Result) values('張三' , '物理' , 93)
insert into tb(Name , Subject , Result) values('李四' , '語文' , 74)
insert into tb(Name , Subject , Result) values('李四' , '數(shù)學(xué)' , 84)
insert into tb(Name , Subject , Result) values('李四' , '物理' , 94)
go
--靜態(tài)SQL,指subject只有語文、數(shù)學(xué)、物理這三門課程。
select name 姓名,
max(case subject when '語文' then result else 0 end) 語文,
max(case subject when '數(shù)學(xué)' then result else 0 end) 數(shù)學(xué),
max(case subject when '物理' then result else 0 end) 物理
from tb
group by name
/*
姓名 語文 數(shù)學(xué) 物理
---------- ----------- ----------- -----------
李四 74 84 94
張三 74 83 93
*/
--動(dòng)態(tài)SQL,指subject不止語文、數(shù)學(xué)、物理這三門課程。
declare @sql varchar(8000)
set @sql = 'select Name as ' + '姓名'
select @sql = @sql + ' , max(case Subject when ''' + Subject + ''' then Result else 0 end) [' + Subject + ']'
from (select distinct Subject from tb) as a
set @sql = @sql + ' from tb group by name'
exec(@sql)
/*
姓名 數(shù)學(xué) 物理 語文
---------- ----------- ----------- -----------
李四 84 94 74
張三 83 93 74
*/
-------------------------------------------------------------------
/*加個(gè)平均分,總分
姓名 語文 數(shù)學(xué) 物理 平均分 總分
---------- ----------- ----------- ----------- -------------------- -----------
李四 74 84 94 84.00 252
張三 74 83 93 83.33 250
*/
--靜態(tài)SQL,指subject只有語文、數(shù)學(xué)、物理這三門課程。
select name 姓名,
max(case subject when '語文' then result else 0 end) 語文,
max(case subject when '數(shù)學(xué)' then result else 0 end) 數(shù)學(xué),
max(case subject when '物理' then result else 0 end) 物理,
cast(avg(result*1.0) as decimal(18,2)) 平均分,
sum(result) 總分
from tb
group by name
/*
姓名 語文 數(shù)學(xué) 物理 平均分 總分
---------- ----------- ----------- ----------- -------------------- -----------
李四 74 84 94 84.00 252
張三 74 83 93 83.33 250
*/
--動(dòng)態(tài)SQL,指subject不止語文、數(shù)學(xué)、物理這三門課程。
declare @sql1 varchar(8000)
set @sql1 = 'select Name as ' + '姓名'
select @sql1 = @sql1 + ' , max(case Subject when ''' + Subject + ''' then Result else 0 end) [' + Subject + ']'
from (select distinct Subject from tb) as a
set @sql1 = @sql1 + ' , cast(avg(result*1.0) as decimal(18,2)) 平均分,sum(result) 總分 from tb group by name'
exec(@sql1)
/*
姓名 數(shù)學(xué) 物理 語文 平均分 總分
---------- ----------- ----------- ----------- -------------------- -----------
李四 84 94 74 84.00 252
張三 83 93 74 83.33 250
*/
drop table tb
---------------------------------------------------------
---------------------------------------------------------
/*
如果上述兩表互相換一下:即
姓名 語文 數(shù)學(xué) 物理
張三 748393
李四 748494
想變成
Name Subject Result
---------- ------- -----------
李四 語文 74
李四 數(shù)學(xué) 84
李四 物理 94
張三 語文 74
張三 數(shù)學(xué) 83
張三 物理 93
*/
create table tb1
(
姓名 varchar(10) ,
語文 int ,
數(shù)學(xué) int ,
物理 int
)
insert into tb1(姓名 , 語文 , 數(shù)學(xué) , 物理) values('張三',74,83,93)
insert into tb1(姓名 , 語文 , 數(shù)學(xué) , 物理) values('李四',74,84,94)
select * from
(
select 姓名 as Name , Subject = '語文' , Result = 語文 from tb1
union all
select 姓名 as Name , Subject = '數(shù)學(xué)' , Result = 數(shù)學(xué) from tb1
union all
select 姓名 as Name , Subject = '物理' , Result = 物理 from tb1
) t
order by name , case Subject when '語文' then 1 when '數(shù)學(xué)' then 2 when '物理' then 3 when '總分' then 4 end
--------------------------------------------------------------------
/*加個(gè)平均分,總分
Name Subject Result
---------- ------- --------------------
李四 語文 74.00
李四 數(shù)學(xué) 84.00
李四 物理 94.00
李四 平均分 84.00
李四 總分 252.00
張三 語文 74.00
張三 數(shù)學(xué) 83.00
張三 物理 93.00
張三 平均分 83.33
張三 總分 250.00
*/
select * from
(
select 姓名 as Name , Subject = '語文' , Result = 語文 from tb1
union all
select 姓名 as Name , Subject = '數(shù)學(xué)' , Result = 數(shù)學(xué) from tb1
union all
select 姓名 as Name , Subject = '物理' , Result = 物理 from tb1
union all
select 姓名 as Name , Subject = '平均分' , Result = cast((語文 + 數(shù)學(xué) + 物理)*1.0/3 as decimal(18,2)) from tb1
union all
select 姓名 as Name , Subject = '總分' , Result = 語文 + 數(shù)學(xué) + 物理 from tb1
) t
order by name , case Subject when '語文' then 1 when '數(shù)學(xué)' then 2 when '物理' then 3 when '平均分' then 4 when '總分' then 5 end
drop table tb1
declare @cmdText varchar(8000)
2 set @cmdText='select userName, '
3 select @cmdText=@cmdText+' sum(case payType when'''+payType+'''Then money else 0 end) as '''+payType
4 +''','+char(10) from (select Distinct payType from PayPhoneMoney) T
5 print @cmdText--發(fā)現(xiàn)多一個(gè)逗號下面把逗號去掉
6 set @cmdText=left(@cmdText,len(@cmdText)-2)--去掉逗號
7 set @cmdText=@cmdText+'from PayPhoneMoney group by userName'
8 print @cmdText
9 exec(@cmdText)
select a.name,a.checi,a.date,a.time,b.checi,b.date,b.time from matable a inner join matable b on a.name=b.name group by a.name
方法如下:
1、首先打開Mysql命令行編輯器,連接Mysql數(shù)據(jù)庫;
2、使用所要操作的數(shù)據(jù)庫,先顯示一下數(shù)據(jù)庫中的表;
3、顯示一下表結(jié)構(gòu),了解一下表中的列;
4、向表插入數(shù)據(jù),insert into 表名 (列名) values (值);
5、查詢表可以看到所插入的數(shù)據(jù),select * from 表名;
6、可以再插入一個(gè)數(shù)據(jù),顯示一下。
擴(kuò)展資料:
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典MySQL AB 公司開發(fā),目前屬于?Oracle?旗下產(chǎn)品。MySQL 是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,在 WEB 應(yīng)用方面,MySQL是最好的?RDBMS?(Relational Database Management System,關(guān)系數(shù)據(jù)庫管理系統(tǒng)) 應(yīng)用軟件。
MySQL是一種關(guān)系數(shù)據(jù)庫管理系統(tǒng),關(guān)系數(shù)據(jù)庫將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉庫內(nèi),這樣就增加了速度并提高了靈活性。
MySQL所使用的 SQL 語言是用于訪問數(shù)據(jù)庫的最常用標(biāo)準(zhǔn)化語言。MySQL 軟件采用了雙授權(quán)政策,分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點(diǎn),一般中小型網(wǎng)站的開發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫。
由于其社區(qū)版的性能卓越,搭配?PHP?和?Apache?可組成良好的開發(fā)環(huán)境。
與其他的大型數(shù)據(jù)庫,例如?Oracle、DB2、SQL Server等相比,MySQL自有它的不足之處,但是這絲毫也沒有減少它受歡迎的程度。對于一般的個(gè)人使用者和中小型企業(yè)來說,MySQL提供的功能已經(jīng)綽綽有余,而且由于 MySQL是開放源碼軟件,因此可以大大降低總體擁有成本。
Linux作為操作系統(tǒng),Apache?或Nginx作為?Web?服務(wù)器,MySQL 作為數(shù)據(jù)庫,PHP/Perl/Python作為服務(wù)器端腳本解釋器。由于這四個(gè)軟件都是免費(fèi)或開放源碼軟件(FLOSS),因此使用這種方式不用花一分錢(除開人工成本)就可以建立起一個(gè)穩(wěn)定、免費(fèi)的網(wǎng)站系統(tǒng),被業(yè)界稱為“LAMP“或“LNMP”組合。
MyISAMMySQL 5.0 之前的默認(rèn)數(shù)據(jù)庫引擎,最為常用。擁有較高的插入,查詢速度,但不支持事務(wù)
InnoDB事務(wù)型數(shù)據(jù)庫的首選引擎,支持ACID事務(wù),支持行級鎖定, MySQL 5.5 起成為默認(rèn)數(shù)據(jù)庫引擎
BDB源 自 Berkeley DB,事務(wù)型數(shù)據(jù)庫的另一種選擇,支持Commit 和Rollback 等其他事務(wù)特性
Memory所有數(shù)據(jù)置于內(nèi)存的存儲(chǔ)引擎,擁有極高的插入,更新和查詢效率。但是會(huì)占用和數(shù)據(jù)量成正比的內(nèi)存空間。并且其內(nèi)容會(huì)在 MySQL 重新啟動(dòng)時(shí)丟失
Merge將一定數(shù)量的 MyISAM 表聯(lián)合而成一個(gè)整體,在超大規(guī)模數(shù)據(jù)存儲(chǔ)時(shí)很有用
Archive非常適合存儲(chǔ)大量的獨(dú)立的,作為歷史記錄的數(shù)據(jù)。因?yàn)樗鼈儾唤?jīng)常被讀取。Archive 擁有高效的插入速度,但其對查詢的支持相對較差
Federated將不同的 MySQL 服務(wù)器聯(lián)合起來,邏輯上組成一個(gè)完整的數(shù)據(jù)庫。非常適合分布式應(yīng)用
Cluster/NDB高冗余的存儲(chǔ)引擎,用多臺數(shù)據(jù)機(jī)器聯(lián)合提供服務(wù)以提高整體性能和安全性。適合數(shù)據(jù)量大,安全和性能要求高的應(yīng)用
CSV: 邏輯上由逗號分割數(shù)據(jù)的存儲(chǔ)引擎。它會(huì)在數(shù)據(jù)庫子目錄里為每個(gè)數(shù)據(jù)表創(chuàng)建一個(gè) .csv 文件。這是一種普通文本文件,每個(gè)數(shù)據(jù)行占用一個(gè)文本行。CSV 存儲(chǔ)引擎不支持索引。
BlackHole:黑洞引擎,寫入的任何數(shù)據(jù)都會(huì)消失,一般用于記錄 binlog 做復(fù)制的中繼
EXAMPLE 存儲(chǔ)引擎是一個(gè)不做任何事情的存根引擎。它的目的是作為 MySQL?源代碼中的一個(gè)例子,用來演示如何開始編寫一個(gè)新存儲(chǔ)引擎。同樣,它的主要興趣是對開發(fā)者。EXAMPLE 存儲(chǔ)引擎不支持編索引。
另外,MySQL 的存儲(chǔ)引擎接口定義良好。有興趣的開發(fā)者可以通過閱讀文檔編寫自己的存儲(chǔ)引擎。
參考資料來源:百度百科:mySQL