mysql中常用的三種插入數(shù)據(jù)的語(yǔ)句:
目前創(chuàng)新互聯(lián)建站已為上千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、雨城網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶(hù)導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶(hù)和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
1、insert into表示插入數(shù)據(jù),數(shù)據(jù)庫(kù)會(huì)檢查主鍵(PrimaryKey),如果出現(xiàn)重復(fù)會(huì)報(bào)錯(cuò);
2、replace into表示插入替換數(shù)據(jù),需求表中有PrimaryKey,或者unique索引的話(huà),如果數(shù)據(jù)庫(kù)已經(jīng)存在數(shù)據(jù),則用新數(shù)據(jù)替換,如果沒(méi)有數(shù)據(jù)效果則和insert into一樣;
3、REPLACE語(yǔ)句會(huì)返回一個(gè)數(shù),來(lái)指示受影響的行的數(shù)目。該數(shù)是被刪除和被插入的行數(shù)的和。如果對(duì)于一個(gè)單行REPLACE該數(shù)為1,則一行被插入,同時(shí)沒(méi)有行被刪除。如果該數(shù)大于1,則在新行被插入前,有一個(gè)或多個(gè)舊行被刪除。如果表包含多個(gè)唯一索引,并且新行復(fù)制了在不同的唯一索引中的不同舊行的值,則有可能是一個(gè)單一行替換了多個(gè)舊行。
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開(kāi)發(fā),目前屬于 Oracle 旗下產(chǎn)品。MySQL 最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),在 WEB 應(yīng)用方面MySQL是最好的 RDBMS (Relational Database Management System,關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)) 應(yīng)用軟件之一。
MySQL是一種關(guān)聯(lián)數(shù)據(jù)庫(kù)管理系統(tǒng),關(guān)聯(lián)數(shù)據(jù)庫(kù)將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉(cāng)庫(kù)內(nèi),這樣就增加了速度并提高了靈活性。
insert into是mysql中最常用的插入語(yǔ)句,它有6種寫(xiě)法。
如果插入的記錄是數(shù)字的話(huà)要在數(shù)字的逗號(hào)后面加n:
通過(guò)以上實(shí)例我們可以看到insert into語(yǔ)句只能向原表中插入于其字段對(duì)應(yīng)的數(shù)據(jù),那么能不能通過(guò)insert into語(yǔ)句來(lái)把其他表的數(shù)據(jù)插入到原表中呢:
在MySQL中set方法:
ModifyStatement.Set Method 修改語(yǔ)句 set方法
Sets key and value. 設(shè)置鍵和值。
由于insert into語(yǔ)句是一個(gè)插入性的語(yǔ)句,所以它的功能要么向指定的表插入數(shù)據(jù)
也許你看到這個(gè)SQL語(yǔ)句是正確的,就覺(jué)得這樣應(yīng)該也可以:
mysql mysql insert into 4a set sname=4ainall.sname;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'mysql insert into 4a set sname=4ainall.sname' at line 1
或者這樣也可以:
mysql mysql insert into 4a set sname="趙六";
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'mysql insert into 4a set sname="趙六"' at line 1
然后這樣也是不可用:
mysql insert into 4a select * from 4ainall set sname=4ainall.sname;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'from 4ainall set sname=4ainall.sname' at line 1
可以看出由于select是作用于4inall這個(gè)表的,而set方法也只能在select語(yǔ)句中,這就直接導(dǎo)致set方法只能作用于4inall這個(gè)表,而無(wú)法作用于4a這個(gè)表。
但是如果我們不用select語(yǔ)句的話(huà)編譯器又怎么會(huì)知道4inall表中的數(shù)據(jù)在哪里?
顯然select是用于查的而set則是一個(gè)用于改的方法,兩者無(wú)法結(jié)合在一起——insert into set語(yǔ)句當(dāng)然也不能用于將其他表的數(shù)據(jù)插入到原表中了。
INSERT INTO mt_message (`id`,`name` ,`tel` ,`email` )VALUES (NULL,'111111111', '11', '1')
INSERT INTO mt_message(`id` ,`name` ,`tel` ,`email` ,`qita` ,`content` ,`shijian` ,`user` ,`huifu` ,`shenhe`
//)VALUES (NULL , '1', '2', '', '', '', NOW( ) , '', '', '')
只能說(shuō)明:你從email開(kāi)始后面的字段其中有一個(gè)是不能為空的,而且沒(méi)有初始值
所以你第一個(gè)語(yǔ)句插入失敗了
我估計(jì)應(yīng)該問(wèn)題就是在你的時(shí)間(shijian)字段,因?yàn)楹竺婊径际强盏?,只有時(shí)間不是
你可以去檢查一個(gè)你的這張message表,在mysql命令行用:desc message
檢查數(shù)據(jù)表的字段名和字段屬性,如果不行你可以重新建立數(shù)據(jù)表的
要是想知道出錯(cuò)在哪里,你可以這樣寫(xiě):
?php
//..上面程序略
$sql="INSERT INTO mt_message (`id`,`name` ,`tel` ,`email` )VALUES (NULL,'111111111', '11', '1')";
$query=mysql_query($sql);
//執(zhí)行
if($query)
//執(zhí)行成功
echo 'OK';
else
echo '插入失敗,錯(cuò)誤報(bào)告是:'.mysql_error();
//輸出mysql錯(cuò)誤信息函數(shù):mysql_error();
?
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開(kāi)發(fā),目前屬于?Oracle?旗下產(chǎn)品。MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)之一,在 WEB 應(yīng)用方面,MySQL是最好的 RDBMS (Relational Database Management System,關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)) 應(yīng)用軟件。
MySQL是一種關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),關(guān)系數(shù)據(jù)庫(kù)將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉(cāng)庫(kù)內(nèi),這樣就增加了速度并提高了靈活性。
MySQL所使用的 SQL 語(yǔ)言是用于訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的最常用標(biāo)準(zhǔn)化語(yǔ)言。MySQL 軟件采用了雙授權(quán)政策,分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開(kāi)放源碼這一特點(diǎn),一般中小型網(wǎng)站的開(kāi)發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫(kù)。
由于其社區(qū)版的性能卓越,搭配?PHP?和?Apache?可組成良好的開(kāi)發(fā)環(huán)境。