mysql基本語句詳細教程
看他們網上的,寫得都是千篇一律,同時,好多也寫得不是很好,下面是我自己總結的有關mysql的使用細節,也是我在學習過程中的一些記錄吧,希望對你有點幫助,后面有關存儲過程等相關操作還沒有總結好,下次總結好了再發給你吧,呵呵~~~~~MySql學習筆記MySql概述:MySql是一個種關聯數據庫管理系統,所謂關聯數據庫就是將數據保存在不同的表中,而不是將所有數據放在一個大的倉庫中。
這樣就增加了速度與提高了靈活性。并且MySql軟件是一個開放源碼軟件。
注意,MySql所支持的TimeStamp的最大范圍的問題,在32位機器上,支持的取值范圍是年份最好不要超過2030年,然后如果在64位的機器上,年份可以達到2106年,而對于date、與datetime這兩種類型,則沒有關系,都可以表示到9999-12-31,所以這一點得注意下;還有,在安裝MySql的時候,我們一般都選擇Typical(典型安裝)就可以了,當然,如果還有其它用途的話,那最好選擇Complete(完全安裝);在安裝過程中,一般的還會讓你進行服務器類型的選擇,分別有三種服務器類型的選擇,(Developer(開發機)、Server Machine(服務器)、Dedicated MySql Server Machine(專用MYSQL服務器)),選擇哪種類型的服務器,只會對配置向導對內存等有影響,不然其它方面是沒有什么影響的;所以,我們如果是開發者,選擇開發機就可以啦;然后接下來,還會有數據庫使用情況對話框的選擇,我們只要按照默認就可以啦;連接與斷開服務器:連接:在windows命令提示符下輸入類似如下命令集:mysql –h host –u user –p例如,我在用的時候輸入的是:mysql –h localhost –u root –p然后會提示要你輸入用戶密碼,這個時候,如果你有密碼的話,就輸入密碼敲回車,如果沒有密碼,直接敲回車,就可以進入到數據庫客戶端;連接遠程主機上的mysql,可以用下面的命令:mysql –h 159.0.45.1 –u root –p 123斷開服務器:在進入客戶端后,你可以直接輸入quit然后回車就可以了;下面就數據庫相關命令進行相關說明你可以輸入以下命令對數據庫表格或者數據庫進行相關操作,在這里就省略了,然后直接進行文字說明了;Select version(),current_date;//從服務器得到當前mysql的版本號與當前日期Select user(); //得到當前數據庫的所有用戶Use databasename; 進入到指定的數據庫當中,然后就可以操作這個數據庫當中的表格了Show databases; //查詢目前數據庫中所有的數據庫,并且顯示出來;Create batabase databasename;創建數據庫,例如:create database manager;Show tables; //查看當前數據庫中的所有表格;Create table tablename(colums);創建表,并且給表指定相關列,例如:create table pet(name varchar(20),owner varchar(20),species varchar(20),sex char(1),birth date,death date);Describe tablename;將表當中的所有信息詳細顯示出來,例如:describe pet;可以用命令一次插入多條記錄,例如:Insert into pet values('Puffball','Diane','hamster','f','1993-12-3',null),( 'Puffball','Diane','hamster','f','1993-12-3',now());Select * from pet; 從pet表當中查詢出所有的記錄,顯示出來;Delete from pet where id=1;刪除ID為1的那一條記錄;Update pet set birth='2001-1-3' where name='Bowser';更新name為Bowser的記錄當中的birth字段的值;Select distinct owner from pet;從pet表中選擇出owner字段的值唯一的行,如果有多行記錄這個字段的值相同,則只顯示最后一次出現這一值的一行記錄;有關日期計算:Select name,birth,curdate(),(year(curdate())-year(birth)) as age from pet;此處,year()函數用于提取對應字段的年份,當然類似的還有month(),day()等;在mysql當中,sql語句可以使用like查詢,可以用”_”配任何單個字符,用”%”配任意數目字符,并且SQL模式默認是忽略大小寫,例如:select * from pet where name like '%fy';當然也可以用正則表達式模式進行配。同時在sql當中,也要注意分組函數、排序函數、統計函數等相關用法,在這里只列舉一二;Select species,count(*) from pet group by speceis;Select * from pet order by birth desc;查詢最大值的相關操作:Select max(age) from pet;取前多少項記錄,這個主要用于分頁查詢操作當中,Select * from pet order by birth desc limit 3;取前三條記錄,Select * from pet order by birth desc limit 0,3;這個可以用于分頁查詢,limit后面的第一個參數,是起始位置,第二個參數是取記錄條數;有關創建表格自增長字段的寫法:Create table person(id int(4) not null auto_increment,name char(20) not null,primary key (id));修改表操作:向表中增加字段:注意,在這個地方,如果是增加多個字段的時候,就要用括號括起來,不然會有問題,如果是單個字段的話,不用括號也沒事;Alter table test add(address varchar(50) not null default 'xm',email varchar(20) not null);將表中某個字段的名字修改或者修改其。
mysql查詢語句
假設數據庫的表名稱為sunif,執行以下語句即可實現 select 編號, A發 AS 發, A銷 AS 銷, A退 AS 退, A發-A銷-A退 AS 結余, B發 AS 發, B銷 AS 銷, B退 AS 退, B發-B銷-B退 AS 結余 from(select 編號, SUM(CASE when (區域='A區' and 類型='發') then 數量 END ) AS A發, SUM(CASE when (區域='A區' and 類型='銷') then 數量 END) AS A銷, SUM(CASE when (區域='A區' and 類型='退') then 數量 END) AS A退, SUM(CASE when (區域='B區' and 類型='發') then 數量 END ) AS B發, SUM(CASE when (區域='B區' and 類型='銷') then 數量 END) AS B銷, SUM(CASE when (區域='B區' and 類型='退') then 數量 END) AS B退 from sunif group by 編號) as tmp; 說明:根據你的數據源,以上語句可以滿足查詢結果。
如果CASE條件有多個會并行顯示,需要適度增加條件 。
mysql數據庫執行sql語句怎么寫
Mysql常用命令詳解Mysql安裝目錄數據庫目錄/var/lib/mysql/配置文件/usr/share/mysql(*命令及配置文件)相關命令/usr/bin(mysqladmin mysqldump等命令)啟動腳本/etc/init.d/mysql(啟動腳本文件mysql的目錄)系統管理連接MySQL格式: mysql -h 主機地址 -u用戶名 -p用戶密碼例 1:連接到本機上的 MySQL。
hadoop@ubuntu:~$ mysql -uroot -pmysql;例 2:連接到遠程主機上的 MYSQL。hadoop@ubuntu:~$ mysql -h 127.0.0.1 -uroot -pmysql;修改新密碼在終端輸入:mysql -u用戶名 -p密碼,回車進入Mysql。
> use mysql;> update user set password=PASSWORD('新密碼') where user='用戶名';> flush privileges; #更新權限> quit; #退出增加新用戶格式:grant select on 數據庫.* to 用戶名@登錄主機 identified by '密碼'舉例:例 1:增加一個用戶 test1 密碼為 abc,讓他可以在任何主機上登錄,并對所有數據庫有查詢、插入、修改、刪除的權限。首先用以 root 用戶連入 MySQL,然后鍵入以下命令:mysql>grant select,insert,update,delete on *.* to root@localhost identified by 'mysql';或者grant all privileges on *.* to root@localhost identified by 'mysql';然后刷新權限設置。
flush privileges;例 2:如果你不想 root 有密碼操作數據庫“mydb”里的數據表,可以再打一個命令將密碼消掉。grant select,insert,update,delete on mydb.* to root@localhost identified by '';刪除用戶hadoop@ubuntu:~$ mysql -u用戶名 -p密碼mysql>delete from user where user='用戶名' and host='localhost';mysql>flush privileges;//刪除用戶的數據庫mysql>drop database dbname;數據庫操作顯示所有的數據庫mysql> show databases;(注意:最后有個 s)創建數據庫mysql> create database test;連接數據庫mysql> use test;查看當前使用的數據庫mysql> select database();當前數據庫包含的表信息mysql> show tables; (注意:最后有個 s)刪除數據庫mysql> drop database test;表操作備注:操作之前使用“use ”應連接某個數據庫。
建表命令:create table ( [,.. ]);例子:mysql> create table MyClass(> id int(4) not null primary key auto_increment,> name char(20) not null,> sex int(4) not null default '0',> degree double(16,2));獲取表結構命令: desc 表名,或者show columns from 表名例子:mysql> describe MyClassmysql> desc MyClass;mysql> show columns from MyClass;刪除表命令:drop table 例如:刪除表名為 MyClass 的表mysql> drop table MyClass;插入數據命令:insert into [( [,.. ])] values ( 值 1 )[, ( 值 n )]例子:mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);查詢表中的數據查詢所有行mysql> select * from MyClass;查詢前幾行數據例如:查看表 MyClass 中前 2 行數據mysql> select * from MyClass order by id limit 0,2;或者mysql> select * from MyClass limit 0,2;刪除表中數據命令:delete from 表名 where 表達式例如:刪除表 MyClass 中編號為 1 的記錄mysql> delete from MyClass where id=1;修改表中數據命令:update 表名 set 字段=新值,。 where 條件mysql> update MyClass set name='Mary' where id=1;在表中增加字段命令:alter table 表名 add 字段 類型 其他;例如:在表 MyClass 中添加了一個字段 passtest,類型為 int(4),默認值為 0mysql> alter table MyClass add passtest int(4) default '0'更改表名命令:rename table 原表名 to 新表名;例如:在表 MyClass 名字更改為 YouClassmysql> rename table MyClass to YouClass;更新字段內容命令:update 表名 set 字段名 = 新內容update 表名 set 字段名 = replace(字段名, '舊內容', '新內容');例如:文章前面加入 4 個空格update article set content=concat(' ', content);數據庫導入導出從數據庫導出數據庫文件使用“mysqldump”命令首先進入 DOS 界面,然后進行下面操作。
1)導出所有數據庫格式:mysqldump -u [數據庫用戶名] -p -A>[備份文件的保存路徑]2)導出數據和數據結構格式:mysqldump -u [數據庫用戶名] -p [要備份的數據庫名稱]>[備份文件的保存路徑]舉例:例 1:將數據庫 mydb 導出到 e:\MySQL\* 文件中。打開開始->運行->輸入“cmd”,進入命令行模式。
c:\> mysqldump -h localhost -u root -p mydb >e:\MySQL\*然后輸入密碼,等待一會導出就成功了,可以到目標文件中檢查是否成功。例 2:將數據庫 mydb 中的 mytable 導出到 e:\MySQL\* 文件中。
c:\> mysqldump -h localhost -u root -p mydb mytable>e:\MySQL\*例 3:將數據庫 mydb 的結構導出到 e:\MySQL\mydb_* 文件中。c:\> mysqldump -h localhost -u root -p mydb --add-drop-table >e:\MySQL\mydb_*備注:-h localhost 可以省略,其一般在虛擬主機上用。
3)只導出數據不導出數據結構格式:mysqldump -u [數據庫用戶名] -p -t [要備份的數據庫名稱]>[備份文件的保存路徑]4)導出數據庫中的Events格式:mysqldump -u [數據庫用戶名] -p -E [數據庫用戶名]>[備份文件的保存路徑]5)導出數據。
mysql數據庫SQL語句
你好! 由于mysql不能是用正則表達式,通過關聯的方式也能得到結果: 1:創建數據表 CREATE TABLE tests(names VARCHAR(16),chinese INT,math INT,english INT);2:插入測試數據 INSERT INTO tests VALUES ('張三',80,88,98);INSERT INTO tests VALUES ('李四',72,78,98);INSERT INTO tests VALUES ('王五',78,86,98);INSERT INTO tests VALUES ('馬六',89,99,98);INSERT INTO tests VALUES ('趙琪',83,99,98);INSERT INTO tests VALUES ('牛八',98,67,98);COMMIT;3:完成樓主需要的查詢 SELECT * ,*e+*+*h sum_value FROM (SELECT COUNT(*),* FROM tests t1,tests t2 WHERE *e+*+*h <= *e+*+*hGROUP BY *AVING COUNT(*) <=3) t1,tests t2 WHERE * = *4:輸出結果配圖 結論:通過關聯出比自己大的,得到關聯數量最少的三條就是想要的結果; 第二個問題,留給你自己動腦子想想吧! 祝你好運!。
mysql數據庫,排序的語句
在執行查詢結果時,默認情況下查詢結果無序排列。但我們有時需要對數據按一定規則進行排序。這時可以通過ORDER BY子句來實現這個功能。語法如下:
SELECT <*,column [alias],。> FROM table
[WHERE condition(s)]
[ORDER BY column[ASC|DESC]];
默認是ASC指定的升序排列,DESC用來指定降序排列。
1、升序排序:
使用ORDER BY子句時,默認情況下數據是按升序排列的,故可以用ASC關鍵字指點升序排列,或者不指定,默認就是升序,顯示效果是一樣的,如下圖:
2、降序排序:
當需要查詢結果降序排列時,必須在排序后指定DESC關鍵字。如下圖是查看職員薪水的降序排列:
mysql的語句和sql語句是一樣的嗎
總體差不多,但有些小區別;我列給你看看:1 mysql支持enum,和set類型,sql server不支持
2 mysql不支持nchar,nvarchar,ntext類型
3 mysql的遞增語句是AUTO_INCREMENT,而mssql是identity(1,1)
4 msms默認到處表創建語句的默認值表示是((0)),而在mysql里面是不允許帶兩括號的
5 mysql需要為表指定存儲類型
6 mssql識別符是[],[type]表示他區別于關鍵字,但是mysql卻是 `,也就是按鍵1左邊的那個符號
7 mssql支持getdate()方法獲取當前時間日期,但是mysql里面可以分日期類型和時間類型,獲取當前日期是cur_date(),當前完整時間是 now()函數
8 mssql不支持replace into 語句,但是在最新的sql20008里面,也支持merge語法
9 mysql支持insert into table1 set t1 = '', t2 = '' ,但是mssql不支持這樣寫
10 mysql支持insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1)
11 mssql不支持limit語句,是非常遺憾的,只能用top 取代limt 0,N,row_number() over()函數取代limit N,M
12 mysql在創建表時要為每個表指定一個存儲引擎類型,而mssql只支持一種存儲引擎
13 mysql不支持默認值為當前時間的datetime類型(mssql很容易做到),在mysql里面是用timestamp類型
14 mssql里面檢查是否有這個表再刪除,需要這樣:
if exists (select * from *ects where id = object_id(N'uc_newpm') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
但是在mysql里面只需要 DROP TABLE IF EXISTS cdb_forums;
15 mysql支持無符號型的整數,那么比不支持無符號型的mssql就能多出一倍的最大數存儲
16 mysql不支持在mssql里面使用非常方便的varchar(max)類型,這個類型在mssql里面既可做一般數據存儲,也可以做blob數據存儲
17 mysql創建非聚集索引只需要在創建表的時候指定為key就行,比如:KEY displayorder (fid,displayorder) 在mssql里面必須要:create unique nonclustered index index_uc_protectedmembers_username_appid on *_protectedmembers
(username asc,appid asc)
18 mysql text字段類型不允許有默認值
19mysql的一個表的總共字段長度不超過65XXX。
20一個很表面的區別就是mysql的安裝特別簡單,而且文件大小才110M(非安裝版),相比微軟這個龐然大物,安裝進度來說簡直就是。..
21mysql的管理工具有幾個比較好的,mysql_front,和官方那個套件,不過都沒有SSMS的使用方便,這是mysql很大的一個缺點。
22mysql的存儲過程只是出現在最新的版本中,穩定性和性能可能不如mssql。
23 同樣的負載壓力,mysql要消耗更少的CPU和內存,mssql的確是很耗資源。
24php連接mysql和mssql的方式都差不多,只需要將函數的mysql替換成mssql即可。
25mysql支持date,time,year類型,mssql到2008才支持date和time。
mysql數據庫的SQL語句和oracle的有什么區別
7) mysql的group by 語句可以select 沒有被分組的字段,如
select id,name,age from A group by age 這樣
但是在orcale和sqlserver中是會報錯的。這個取出的id,name所在的行是每個分組中的第一行數據。
8)orcale用decode()來轉換數據,mysql,sqlserver用case when:
case *_RESULT when '2402' then *ID end (必須有end)
9)mysql: 兩個select 出的數據相減:
(COUNT(distinct(*ID))-
CONVERT((COUNT(distinct(case *_RESULT when '2402' then *ID end))), SIGNED)) AS NEGATIVE
FROM `view_sims_for_report` t
10)convert,cast用法
mysql將varchar轉為int
convert(字段名, SIGNED)
字符集轉換 : CONVERT(xxx USING gb2312)
類型轉換和SQL Server一樣,就是類型參數有點不同 : CAST(xxx AS 類型) , CONVERT(xxx,類型)
可用的類型
二進制,同帶binary前綴的效果 : BINARY
字符型,可帶參數 : CHAR()
日期 : DATE
時間: TIME
日期時間型 : DATETIME
浮點數 : DECIMAL
整數 : SIGNED
無符號整數 : UNSIGNED
參考資料:http://**article/*
轉載請注明出處華閱文章網 » mysql數據庫語句