The database leakage of account information on various websites at the end of last year was very impressive. I took the opportunity to download several databases and prepared to learn from data analysts to analyze these account information. Although this data information has been "organized", it is quite useful to study by yourself, after all, there is such a large amount of data.
The problem caused by the large amount of data is that a single file is very large. It is not easy to open this file. Don't expect Notepad to crash. The client using MSSQL cannot open such a large SQL file and directly reports insufficient memory. The reason is said to be that when MSSQL reads data, it puts the read data into the memory at once. If the amount of data is too large, Large, and insufficient memory will directly cause the system to crash.
Navicat Premium
Here is a recommended software, Navicat Premium, which is quite powerful. SQL files of hundreds of megabytes can be opened easily without any lag. Moreover, this client software supports connections to various databases such as MSSQL, MYSQL, Oracle, etc. I will slowly study many other functions by myself.
Although Navicat can be used to open the 274MB SQL file CSDN, the content is meaningless, and it is inconvenient to query, classify, make statistics, etc. on these account information. The only way is to read the data one by one, then split the different fragments of each record, and then store these fragments in the database in the format of data fields, so that they can be used conveniently in the future.
Use PHP to read very large files
PHP has many ways to read files. Depending on the target file, adopting a more appropriate method can effectively improve execution efficiency. Since the CSDN database file is very large, we try not to read it all in a short time. After all, every time a piece of data is read, it needs to be split and written. Then a more appropriate way is to read the file area by area. By using PHP's fseek and fread combined, you can read a certain part of the data in the file at will. The following is an example code:
function readBigFile($filename, $count = 20, $tag = "rn") {
$content = "";//Final content
$current = "";//Currently read content storage
$step= 1;//How many characters to go each time
$tagLen = strlen($tag);
$start = 0;//Starting position
$i = 0;//Counter
$handle = fopen($filename,'r+');//Read and write Open the file in mode, and the pointer points to the starting position of the file
while($i fseek($handle, $start, SEEK_SET);//The pointer is set in the file Beginning
$current = fread($handle,$step);//Read file
$content .= $current;//Combining string
$start += $step;//According to step Long forward move
//Truncate the last few characters of the string according to the length of the delimiter
$substrTag = substr($content, -$tagLen);
if ($substrTag == $tag) { // Determine whether it is a newline or other delimiter
$i++;
$content .= "
";
}
}
//Close File
fclose($handle);
//Return result
return $content;
}
$filename = "csdn.sql";//File to be read
$tag = "n";//Line separator. Note that double quotes must be used here
$count = 100;//Read number of lines
$data = readBigFile($filename,$count,$tag);
echo $data;
Regarding the value of the variable $tag passed in by the function, the value passed in is also different depending on the system: Windows uses "rn", Linux/unix uses "n", and Mac OS uses "r".
The general process of program execution: first define some basic variables for reading files, then open the file, position the pointer at the specified position of the file, and read the content of the specified size. Store the content in a variable each time it is read until the required number of lines to read is reached or the end of the file.
Never assume that everything in a program will work as planned.
According to the above code, although the data at the specified location and size in the file can be obtained, the entire process is only executed once and not all the data can be obtained. In fact, to get all the data, you can add a loop to determine whether the file ends in the outer layer of this loop, but this is a waste of system resources, and may even cause PHP execution timeout because the file is too large and cannot be read to the end. Another method is to record and store the position of the pointer after the last time the data was read, and then when the loop is executed again, position the pointer at the last ending position, so that there is no loop to read the file from beginning to end. situation.
Actually, I haven’t imported the CSDN database into the database yet, because there was an analysis on CNBETA a few days after the leak. Haha, the action was too fast. When you see that others have already done this, you automatically don’t have much motivation to do it, but in order to learn, you still have to take the time to complete it.

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Chinese version
Chinese version, very easy to use

Dreamweaver Mac version
Visual web development tools