工具/材料:Management Studio。
主要從事網(wǎng)頁設計、PC網(wǎng)站建設(電腦版網(wǎng)站建設)、wap網(wǎng)站建設(手機版網(wǎng)站建設)、成都響應式網(wǎng)站建設公司、程序開發(fā)、微網(wǎng)站、小程序開發(fā)等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)積累了豐富的成都網(wǎng)站制作、網(wǎng)站建設、網(wǎng)絡營銷經(jīng)驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體,具備承接不同規(guī)模與類型的建設項目的能力。
1、首先在桌面上,點擊“Management Studio”圖標。
2、之后在該界面中,點擊左上角“新建查詢”選項。
3、接著在該界面中,輸入查詢數(shù)據(jù)庫是否有某個字段的sql語句“select count(*) from information_schema.columns where table_name = 'test1' and column_name = 'grade'”。
4、然后在該界面中,點擊左上方“執(zhí)行”按鈕。
5、最后在該界面中,顯示查詢數(shù)據(jù)庫有某個字段。
所有數(shù)據(jù)庫名的命令
show
databases
表結(jié)構(gòu)和列結(jié)構(gòu)
desc
tablename
進入MySQL
Command
line
client下查看當前使用的數(shù)據(jù)庫:mysqlselect
database();mysqlstatus;mysqlshow
tables;mysqlshow
databases;//可以查看有哪些數(shù)據(jù)庫,返回數(shù)據(jù)庫名(databaseName)mysqluse
databaseName;
//更換當前使用的數(shù)據(jù)庫mysqlshow
tables;
//返回當前數(shù)據(jù)庫下的所有表的名稱或者也可以直接用以下命令mysqlshow
tables
from
databaseName;//databaseName可以用show
databases得來mysql查看表結(jié)構(gòu)命令
SQL模糊查詢的語法為
“SELECT column FROM table WHERE column LIKE ';pattern';”。
SQL提供了四種匹配模式:
1. % 表示任意0個或多個字符。如下語句:
SELECT * FROM user WHERE name LIKE ';%三%';
將會把name為“張三”,“三腳貓”,“唐三藏”等等有“三”的全找出來;
2. _ 表示任意單個字符。語句:
SELECT * FROM user WHERE name LIKE ';_三_';
只找出“唐三藏”這樣name為三個字且中間一個字是“三”的;
SELECT * FROM user WHERE name LIKE ';三__';
只找出“三腳貓”這樣name為三個字且第一個字是“三”的;
3. [ ] 表示括號內(nèi)所列字符中的一個(類似與正則表達式)。語句:
SELECT * FROM user WHERE name LIKE ';[張李王]三';
將找出“張三”、“李三”、“王三”(而不是“張李王三”);
如 [ ] 內(nèi)有一系列字符(01234、abcde之類的)則可略寫為“0-4”、“a-e”
SELECT * FROM user WHERE name LIKE ';老[1-9]';
將找出“老1”、“老2”、……、“老9”;
如要找“-”字符請將其放在首位:';張三[-1-9]';
4. [^ ] 表示不在括號所列之內(nèi)的單個字符。語句:
SELECT * FROM user WHERE name LIKE ';[^張李王]三';
將找出不姓“張”、“李”、“王”的“趙三”、“孫三”等;
SELECT * FROM user WHERE name LIKE ';老[^1-4]';
將排除“老1”到“老4”尋找“老5”、“老6”、……、“老9”。
!最后是重點!
由于通配符的緣故,導致我們查詢特殊字符“%”、“_”、“[”、“';”的語句無法正常實現(xiàn),而把特殊字符用“[ ]”括起便可正常查詢。據(jù)此我們寫出以下函數(shù):
function sqlencode(str)
str=replace(str,"';","';';")
str=replace(str,"[","[[]") ';此句一定要在最先
str=replace(str,"_","[_]")
str=replace(str,"%","[%]")
sqlencode=str
end function
以下語句調(diào)試通過:
SELECT?*?FROM?course?WHERE?name?LIKE?'%曉%'
運行效果:
注意事項:
使用 like %name% 這樣的語句是不會走索引的,相當于全表掃描;
數(shù)據(jù)量小的時候不會有太大的問題,數(shù)據(jù)量大了以后性能會下降的很厲害;
建議數(shù)據(jù)量大了以后使用搜索引擎來代替這種模糊搜索;
實在不行也要在模糊查詢前加個能走索引的條件。