本文目錄一覽:
- 1、PHP 怎麼循環一組數字(1萬條數據)插入數據庫?
- 2、php 生成不重複隨機數(組)的幾種方法
- 3、php 生成多個(比如1w個)不重複的12位隨機數,請教!
- 4、php 從excel讀取1萬條數據插入數據庫優化
- 5、PHP產生不重複隨機數的5個方法總結
PHP 怎麼循環一組數字(1萬條數據)插入數據庫?
1W條數據量也不是特別大,那就直接讀取,然後在foreach入庫就可以了
如果數據量非常大的時候,那就分段讀取,然後入庫~
考慮到php超時,那就網頁端打開,第一部分執行完,刷新頁面,開始執行第二部分,依次進行…
當然,直接在命令行下執行也可以~
php 生成不重複隨機數(組)的幾種方法
您好,很高興回答您的問題
$numbers = range (1,50);
//將數組順序隨機打亂
shuffle ($numbers);
//取該數組中的某一段
$result = array_slice($numbers,0,6);
print_r($result);
$tmp=array();
while(count($tmp)5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
php 生成多個(比如1w個)不重複的12位隨機數,請教!
一般來說你一次搞這麼多隨機數,每次單獨隨機排重,1w個隨機數弄下來效率就不行了,比較隨機函數算法還是效率不是很高;
我感覺最簡單做法,先弄好12位按順序生成大數組,第一種就是array_rand
隨機取,第二種就是把12打亂,然後用array_slice取1萬條;
你這個問題我關注一下,看看其他有沒有好辦法。
php 從excel讀取1萬條數據插入數據庫優化
1.你在數據庫進行設置,不允許重複數據.然後隨便寫入就可以了.
2.你可以先把這些數據全部添加進去,不管重複不重複,然後再到數據庫去查有重複數據就刪掉只留一條.
PHP產生不重複隨機數的5個方法總結
無論是Web應用,還是WAP或者移動應用,隨機數都有其用武之地。在最近接觸的幾個小項目中,我也經常需要和隨機數或者隨機數組打交道,所以,對於PHP如何產生不重複隨機數常用的幾種方法小結一下(ps:方法1、4、5是我常用的,其餘來自網絡整理)
方法一:
複製代碼
代碼如下:
?php
$numbers
=
range
(1,50);
//shuffle
將數組順序隨即打亂
shuffle
($numbers);
//array_slice
取該數組中的某一段
$num=6;
$result
=
array_slice($numbers,0,$num);
print_r($result);
?
方法二:
複製代碼
代碼如下:
?php
$numbers
=
range
(1,20);
//播下隨機數發生器種子,可有可無,測試後對結果沒有影響
srand
((float)microtime()*1000000);
shuffle
($numbers);
//跳過list第一個值(保存的是索引)
while
(list(,
$number)
=
each
($numbers))
{
echo
“$number
“;
}
?
方法三:
複製代碼
代碼如下:
?php
function
NoRand($begin=0,$end=20,$limit=5){
$rand_array=range($begin,$end);
shuffle($rand_array);//調用現成的數組隨機排列函數
return
array_slice($rand_array,0,$limit);//截取前$limit個
}
print_r(NoRand());
?
上述可以在1-20間隨機產生5個不重複的值
方法四:
複製代碼
代碼如下:
?php
$tmp=array();
while(count($tmp)5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
?
方法五:
複製代碼
代碼如下:
?php
$tmp
=
range(1,30);
print_r(array_rand($tmp,10));
?
這個可能是比叫簡單的了(ps:如果在range中指定了步長,就必須注意array_rand的第二個參數是否超出$tmp的長度)。
PHP提供非常豐富的數組函數,產生隨機數大多可以從數組這個角度出發,若你還有方法提供,歡迎給出,文章將持續更新。
原創文章,作者:ESHZS,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/313388.html