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基本語句詳細教程
看他們網上的,寫得都是千篇一律,同時,好多也寫得不是很好,下面是我自己總結的有關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);將表中某個字段的名字修改或者修改其對應的相關屬性的時候,要用change對其進行操作;Alter table test change email email 。
mysql 語句
Mysql有自己的語法的 看看教程吧1. 連接mysql:mysqlbinmysql -h主機地址 -u 用戶名 -p 用戶密碼2.退出mysql:exit3. 修改密碼:mysqlbinmysqladmin -uroot -p(oldpassword) password newpassword4.增加用戶:添加一個用戶test1 密碼為ABC;讓他可以在任何主機上登錄,并對所有數據庫有查詢、插入、修改、刪除的權限。
首先用以root用戶連入 mysql,然后鍵入以下命令:grant select,insert,update,delete on *.* to test1@"%" Identified by "abc"; 增加一個用戶test2密碼為abc,讓其只可以在localhost上登錄,并可以對數據庫mydb進行查詢、插入、修改、刪除的操作(localhost指本地 主機,即mysql數據庫所在的那臺主機),這樣用戶即使用知道test2的密碼,也無法從internet上直接訪問數據庫,只能通過mysql主機上的web頁 來訪問了。grant select,insert,update,delete on mydb.* to test2@localhost identified by "abc"; 增加一個可以從任何地方連接服務器的一個完全的超級用戶 grant all privileges on *.* to test3@"%" identified by 'password' with grant option;5.刪除授權 revoke select,insert,update,delete om *.* from test2@localhost ;--------------------------------------------------------6.顯示數據庫 show databases;7.顯示數據庫中的表 use dataname;show tables;8.顯示表的結構 describe tablesname;9.建庫 create database 庫名;10.建表 use dataname; create table teacher //建立表TEACHER( id int(3) auto_increment not null primary key,name char(10) not null,address varchar(50) default '深圳',year date); //建表結束//以下為插入字段 insert into teacher values('','glchengang','深圳一中','1976-10-10'); insert into teacher values('','jack','深圳一中','1975-12-23'); 注:在建表中(1) 將ID設為長度為3的數字字段:int(3),并讓它每個記錄自動加一: auto_increment,并不能為空:not null,而且讓它成為主字段primary key(2) 將NAME設為長度為10的字符字段(3) 將ADDRESS設為長度50的字符字段,而且缺省值為深圳。
varchar和char有什么區別 呢,只有等以后的文章再說了。 (4) 將YEAR設為日期字段。
如果你在mysql提示符鍵入上面的命令也可以,但不方便調試。 你可以將以上命令 原樣寫入一個文本文件中假設為*,然后復制到c:下,并在DOS狀態進入目錄 mysql in,然后鍵入以下命令:mysql -uroot -p密碼 < c:* 如果成功,空出一行無任何顯示;如有錯誤,會有提示。
(以上命令已經調試,你 只要將//的注釋去掉即可使用)。11.刪除庫和刪除表 drop dataname; drop tablename;12.將表中的記錄清空 delete from tablename;13.顯示表中的記錄 select * from tablename;14.表重命名 alter table t1 rename t2---------------------------------------------------------15. 備份數據庫 mysqlbinmysqldump -h(ip) -uroot -p(password) databasename > *16. 恢復數據庫 mysqlbinmysql -h(ip) -uroot -p(password) databasename < *17.復制數據庫 mysqldump --all-databases > *18.備份表 mysqlbinmysqldump -h(ip) -uroot -p(password) databasename tablename > *19.恢復表(操作前先把原來的表刪除) mysqlbinmysql -h(ip) -uroot -p(password) databasename tablename < *----------------------------------------------------------20.為了改變列a,從INTEGER改為TINYINT NOT NULL(名字一樣),并且改變列b,從CHAR(10)改為CHAR(20),同時重命名它,從b改為c:ALTER TABLE t2 MODIFY a TINYINT NOT NULL, CHANGE b c CHAR(20); 增加一個新TIMESTAMP列,名為d:ALTER TABLE t2 ADD d TIMESTAMP; 在列d上增加一個索引,并且使列a為主鍵:ALTER TABLE t2 ADD INDEX (d), ADD PRIMARY KEY (a); 刪除列c:ALTER TABLE t2 DROP COLUMN c; 增加一個新的AUTO_INCREMENT整數列,命名為c:ALTER TABLE t2 ADD c INT UNSIGNED NOT NULL AUTO_INCREMENT,ADD INDEX (c); 注意,我們索引了c,因為AUTO_INCREMENT柱必須被索引,并且另外我們聲明c為NOT NULL,因為索引了的列不能是NULL---------------------------------------------------------------21.數據的導入導出 A。
mysqlimport 語法:mysqlbinmysqlimport database *( 文件名需要與表名相同) 參數:-d or --delete 新數據導入數據表中之前刪除數據數據表中的所有信息;-f or --force 不管是否遇到錯誤,mysqlimport將強制繼續插入數據;-i or --ignore mysqlimport跳過或者忽略那些有相同唯一關鍵字的行, 導入文件中的數據將被忽略;-l or -lock-tables 數據被插入之前鎖住表,這樣就防止了, 你在更新數據庫時,用戶的查詢和更新受到影響;--fields-enclosed- by= char 指定文本文件中數據的記錄時以什么括起的, 很多情況下數據以雙引號括起。 默認的情況下數據是沒有被字符括起的。
--fields-terminated- by=char 指定各個數據的值之間的分隔符,在句號分隔的文件中,分隔符是句號。您可以用此選項指定數據之間的分隔符。
默認的分隔符是跳格符 (Tab) --lines-。
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的語句和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 語句怎么寫
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中的sql語言就叫sql語言,中文名叫結構化查詢語言。
簡介:
結構化查詢語言(Structured Query Language)簡稱SQL(發音:/?es kju? ?el/ "S-Q-L"),是一種特殊目的的編程語言,是一種數據庫查詢和程序設計語言,用于存取數據以及查詢、更新和管理關系數據庫系統;同時也是數據庫腳本文件的擴展名。
結構化查詢語言是高級的非過程化編程語言,允許用戶在高層數據結構上工作。它不要求用戶指定對數據的存放方法,也不需要用戶了解具體的數據存放方式,所以具有完全不同底層結構的不同數據庫系統, 可以使用相同的結構化查詢語言作為數據輸入與管理的接口。結構化查詢語言語句可以嵌套,這使它具有極大的靈活性和強大的功能。
1986年10月,美國國家標準協會對SQL進行規范后,以此作為關系式數據庫管理系統的標準語言(ANSI
X3.
135-1986),1987年得到國際標準組織的支持下成為國際標準。不過各種通行的數據庫系統在其實踐過程中都對SQL規范作了某些編改和擴充。所以,實際上不同數據庫系統之間的SQL不能完全相互通用。
結構化查詢語言包含6個部分:
一:數據查詢語言(DQL:Data Query Language):
其語句,也稱為“數據檢索語句”,用以從表中獲得數據,確定數據怎樣在應用程序給出。保留字SELECT是DQL(也是所有SQL)用得最多的動詞,其他DQL常用的保留字有WHERE,ORDER BY,GROUP BY和HAVING。這些DQL保留字常與其他類型的SQL語句一起使用。
二:數據操作語言(DML:Data Manipulation Language):
其語句包括動詞INSERT,UPDATE和DELETE。它們分別用于添加,修改和刪除表中的行。也稱為動作查詢語言。
三:事務處理語言(TPL):
它的語句能確保被DML語句影響的表的所有行及時得以更新。TPL語句包括BEGIN TRANSACTION,COMMIT和ROLLBACK。
四:數據控制語言(DCL):
它的語句通過GRANT或REVOKE獲得許可,確定單個用戶和用戶組對數據庫對象的訪問。某些RDBMS可用GRANT或REVOKE控制對表單個列的訪問。
五:數據定義語言(DDL):
其語句包括動詞CREATE和DROP。在數據庫中創建新表或刪除表(CREAT TABLE 或 DROP TABLE);為表加入索引等。DDL包括許多與人數據庫目錄中獲得數據有關的保留字。它也是動作查詢的一部分。
六:指針控制語言(CCL):
它的語句,像DECLARE CURSOR,FETCH INTO和UPDATE WHERE CURRENT用于對一個或多個表單獨行的操作。
求MySQL數據庫語句 計算某一列的和
MySQL數據庫語句,計算某一列的和用select sum(b) from a就可以了。
下面來補充一些MySql的基本操作命令。注: 表示參數、[]表示可選項連接數據庫:mysql> mysql -u -p;顯示所有數據庫:mysql> show databases;選擇數據庫:mysql> use ;創建一個數據庫:mysql> create database [charset ]; 刪除一個數據庫:mysql> drop database ;修改數據庫名:mysql無法直接修改數據庫名!顯示所有表:mysql> show tables;刪除一張表:mysql> drop table ;修改表名:mysql> rename table to ;清空表:mysql> truncate ;truncate和delete的區別:truncate相當于刪表再重建一張相同結構的表,操作后得到一張全新表;delete只是刪除數據,而且是按照行來刪除,如果表中有自增型字段,其影響還在。
查看表結構:mysql> desc ;快速建一張相似的表:mysql> create table like ; 評論0 0 0 其他回答(3) 最新回答 (3條回答) 匿名用戶 1級 2013-06-29 回答 select sum(b)from a 評論0 0 0 匿名用戶 1級 2013-06-29 回答 select sum(b) from a;b number 評論0 0 0 你的柔情我永遠不懂 1級 2013-06-30 回答 select personname, case sexid when 1 then '男' else '女' end as sexname from personselect 'hahaha' as thecolumn from thetableselect count(*) as cnt from thetable是要這樣的效果嗎 評論0 0 0 你想知道的這里都有 已解決問題:262,007,030 新手幫助 如何提問 如何回答 投訴建議 舉報不良信息 意見反饋及投訴 搜狗問問小程序 企業推廣 – 輸入法 – 瀏覽器 – 隱私政策 – 免責聲明 – 用戶協議 – 幫助 ? 2019 * 京ICP證050897號 select sum(b)from aselect sum(b) from a;b numberselect personname, case sexid when 1 then '男' else '女' end as sexname from personselect 'hahaha' as thecolumn from thetableselect count(*) as cnt from thetable是要這樣的效果嗎。
mysql語句
* 定義一個字符串,這個字符串由 字符,變量組成。
2.字符需要用 “ ” 來括住,而 user 和 pwd 是變量,不需要" " 來括住。
3.字符和變量之間用+來連接,組成sql這個字符串。
為方便說明:把“ 改成 '('和 ')' ,就可以理清其配對關系。
String sql=(select * from admin where username=') + user +(' and password=')+ pwd +(')
'(' 和 最近的')'配對。
括號內的都是字符串。
將'('和')'替換回“ ,就是你給的語句了。
轉載請注明出處華閱文章網 » 數據庫mysql基本語句