㈠ php用foreach將一個長數組循環插入資料庫
重構函數,將一維數組轉成二維數組,
$newArray=[];
for($i=1;$i<=count($arr)/3;$i++){
foreach($arras$key=>$val){
if($key=="item_name_".$i){
$newArray[$i][$key]=$val;
}
}
}
此時$newArray就是一個二維數組。每組數據一個組。然後拼接sql語句插入
㈡ php中怎麼循環插入資料庫
把復選框的值作為參數提交,作為循環的次數
$s1 = $_POST['s1'];//獲取樣品數量
for($i = 1; $i<=$s1; $i++){
$tmp = $_POST['smp'.$i]; //這里是對應循環中的文本框name屬性
$sql = "insert into 表名(欄位....) values('樣品名',數量)";
mysql_query($sql,$conn);
}
這樣寫,能看明白么?
㈢ php foreach循環輸入insert資料庫
你這種方式數據入庫的話,1000w條數據,要連接1000w次資料庫的,性能肯定是差的,因為建立一次資料庫連接是開銷很大的操作
資料庫的插入是支持多條的啊
insert into 表(欄位) values (值),(值2),(值3)
這樣就可以連接一次資料庫,插入多條數據了,可以把1000w條數據分幾組,這樣連接資料庫的次數會大大減少,性能自然就好了
㈣ PHP foreach 防注入請教
php foreach只是個循環函數,沒有注入一說。
注入一般指的是資料庫注入。意思就是使用一些非法字元,改變數據的正常sql語句功能。
當然也有一些注入html標簽的方法破壞網站結構等等。
網站上用戶傳入的數據,經過驗證,並不關foreach的事,使用字元串的相關操作,將非法的html標簽等刪除掉等等。
㈤ php foreach遍歷數據表,順便寫清楚連接mysql資料庫的詳細內容,數據如果為a,表名為b,要遍歷b中所有欄位
<?php
$mysql_server = "127.0.0.1";
$mysql_username = "root";
$mysql_password = "";
$mysql_dbname = "a";
if (isset($_GET['username']) && !empty($_GET['username'])) {
$con = mysql_connect($mysql_server, $mysql_username, $mysql_password) or die ('Could not connect to mysql server!');
mysql_select_db($mysql_dbname) or die('Could not select database!');
$username = $_GET['username'];
$sql = "SELECT 表列名 FROM b";
$arrays=mysql_fetch_assoc(mysql_query($sql));
foreach($arrays['列名'] as $v) { echo $v." "; }
mysql_close($con);
}
?>
㈥ php兩個數組怎麼用foreach循環插入到資料庫中
兩個數組可以合並成一個,也可以分別。
$time
=
date("Y-m-d
H:i:s");
$query=mysql_query("insert
into
comments(user,comment,addtime)values('$user','$txt','$time')");
if($query)
echo
'1';
㈦ PHP中的函數-- foreach()的用法詳解
PHP
4
引入了
foreach
結構,和
Perl
以及其他語言很像。這只是一種遍歷數組簡便方法。foreach
僅能用於數組,當試圖將其用於其它數據類型或者一個未初始化的變數時會產生錯誤。有兩種語法,第二種比較次要但卻是第一種的有用的擴展。
復制代碼
代碼如下:
foreach
(array_expression
as
$value)
statement
foreach
(array_expression
as
$key
=>
$value)
statement
第一種格式遍歷給定的
array_expression
數組。每次循環中,當前單元的值被賦給
$value
並且數組內部的指針向前移一步(因此下一次循環中將會得到下一個單元)。
第二種格式做同樣的事,只除了當前單元的鍵名也會在每次循環中被賦給變數
$key。
自PHP
5
起,還可能遍歷對象。
注意:當
foreach
開始執行時,數組內部的指針會自動指向第一個單元。這意味著不需要在
foreach
循環之前調用
reset()。
注意:除非數組是被引用,foreach
所操作的是指定數組的一個拷貝,而不是該數組本身。foreach對數組指針有些副作用。除非對其重置,在
foreach
循環中或循環後都不要依賴數組指針的值。
自
PHP
5
起,可以很容易地通過在
$value
之前加上
&
來修改數組的元素。此方法將以引用賦值而不是拷貝一個值。
復制代碼
代碼如下:
<?php
$arr
=
array(1,
2,
3,
4);
foreach
($arr
as
&$value)
{
$value
=
$value
*
2;
}
//
$arr
is
now
array(2,
4,
6,
8)
?>
此方法僅在被遍歷的數組可以被引用時才可用(例如是個變數)。
復制代碼
代碼如下:
<?php
foreach
(array(1,
2,
3,
4)
as
&$value)
{
$value
=
$value
*
2;
}
?>
㈧ PHP中foreach函數用法
1.foreach(被foreach的對象(一般是數組)as 內容) {
}
例子
$x = array(1,2,3,4,5)
foreach ($x as $y) {
//這里的y依次為1,2,3,4,5
}
2.foreach(被foreach的對象(一般是數組)as index => 內容) {
}
例子
$x = array(1,2,3,4,5)
foreach ($x as $index => $y) {
//這里的y依次為1,2,3,4,5, $index依次為0,1,2,3,4
}
㈨ PHP通過foreach循環向資料庫中寫入表單項的值的疑問
建議樓主把SQL語句顯示出來,自然就明白問題在哪裡了,我試著簡單說一下,假設你的USER數據表有三個欄位(name、age、sex),_POST提交數據也是這三個欄位的,假設POST的值分別是abc、18、男,那麼帖子的PHP會執行下面的三個SQL語句:
INSERT INTO USER(name) VALUES(abc)
INSERT INTO USER(age) VALUES(18)
INSERT INTO USER(sex) VALUES(男)
現在明白了吧,一、三兩句會語法錯誤,英文沒有在文本欄位添加引號,第二句即使執行成功插入的記錄只有年齡,姓名、性別為空,如果資料庫有限制欄位有效性,那麼第二句插入也會失敗,資料庫需要的語句是:
INSERT INTO USER(name,age,sex) VALUES('abc',18,'男')
如果理解了,自然會下面這樣寫PHP語句:
$sql=<<<END
INSERT INTO USER(name,age,sex)
VALUES('{$_POST['name']}',{$_POST['age']},'{$_POST['sex']}')
END;
㈩ PHP怎麼用foreach循環資料庫里的數據
用while循環例如:
$res = mysql_query("select id,name,description,price,pic_url1 from ebf_procts");
while($pp = mysql_fetch_array($res,MYSQL_ASSOC) or false){
$list[] = $pp;
}