Mysql
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Mysql

Nhập GeoLite2 của MaxMind vào MySQL

network,geoname_id,registered_country_geoname_id,represented_country_geoname_id,is_anonymous_proxy,is_satellite_provider
1.0.0.0/24,2077456,2077456,,0,0
1.0.1.0/24,1814991,1814991,,0,0
1.0.2.0/23,1814991,1814991,,0,0
1.0.4.0/22,2077456,2077456,,0,0

create table thing1
(   network varchar(20) not null,
    geoname_id varchar(20) not null,
    registered_country_geoname_id varchar(20) not null,
    represented_country_geoname_id varchar(20) not null,
    is_anonymous_proxy varchar(20) not null,
    is_satellite_provider varchar(20) not null
);

LOAD DATA INFILE 'c:\\dev\\ipaddr.txt' 
INTO TABLE thing1
FIELDS TERMINATED BY ',' 
LINES TERMINATED BY '\n'
IGNORE 1 LINES
(@v1,@v2,@v3,@v4,@v5,@v6)
set network=ifnull(@v1,''),
geoname_id=ifnull(@v2,''),
registered_country_geoname_id=ifnull(@v3,''),
represented_country_geoname_id=ifnull(@v4,''),
is_anonymous_proxy=ifnull(@v5,''),
is_satellite_provider=ifnull(@v6,'');

Những điều trên phù hợp với tôi.

Bắt đầu chỉnh sửa bên dưới

Đối với phần bên dưới, hãy cố gắng cải thiện câu trả lời này sau những điểm được thực hiện bởi stijn-de-witt trong phần bình luận.

Tuy nhiên, lưu ý rằng blog được tham chiếu trong các nhận xét có lỗi trong câu lệnh cập nhật khi đi vào int. Vì vậy, tạm thời cho đến khi tôi sắp xếp điều đó, tôi đã tìm thấy một sửa đổi varchar như được thấy bên dưới.

Chỉnh sửa1 (cần theo dõi thêm, xem phần bình luận bên dưới câu trả lời):

Alter the table to get a "from ip to ip range"

alter table thing1 add column from_ip varchar(20), add column to_ip varchar(20);
-- note that those two are nullable at the moment. You can always change that later

Cập nhật bảng cho varchar vừa được thêm vào

update thing1
set from_ip=  INET_NTOA(INET_ATON( SUBSTRING_INDEX(network, '/', 1)) 
   & 0xffffffff ^ ((0x1 << ( 32 - SUBSTRING_INDEX(network, '/', -1))  ) -1 )),
to_ip=   INET_NTOA(INET_ATON( SUBSTRING_INDEX(network, '/', 1)) 
   | ((0x100000000 >> SUBSTRING_INDEX(network, '/', -1) ) -1 ))
select * from thing1;

(Đối với tuyên bố cập nhật ở trên, Ghi có cho Bernd Buffen trong câu trả lời này )

Kết quả của tuyên bố cập nhật ở trên:

mysql> select network,from_ip,to_ip from thing1;
+------------+---------+-----------+
| network    | from_ip | to_ip     |
+------------+---------+-----------+
| 1.0.1.0/24 | 1.0.1.0 | 1.0.1.255 |
| 1.0.2.0/23 | 1.0.2.0 | 1.0.3.255 |
| 1.0.4.0/22 | 1.0.4.0 | 1.0.7.255 |
+------------+---------+-----------+

Từ đây, hãy xem Trang hướng dẫn sử dụng MySQL Các chức năng khác cho INET_ATON(expr) .

Chỉnh sửa2 (cảm ơn stijn-de-witt một lần nữa):

alter table thing1 add column uint_from_ip int unsigned, add column uint_to_ip int unsigned;

UPDATE thing1 SET uint_from_ip = inet_aton(SUBSTRING(network, 1, LOCATE('/', network) - 1)), 
uint_to_ip = (inet_aton(SUBSTRING(network, 1, LOCATE('/', network) - 1)) + (pow(2, (32-CONVERT(SUBSTRING(network, LOCATE('/', network) + 1), UNSIGNED INT)))-1));

Kết quả:

select network,from_ip,to_ip,uint_from_ip,uint_to_ip from thing1;
+------------+---------+-----------+--------------+------------+
| network    | from_ip | to_ip     | uint_from_ip | uint_to_ip |
+------------+---------+-----------+--------------+------------+
| 1.0.1.0/24 | 1.0.1.0 | 1.0.1.255 |     16777472 |   16777727 |
| 1.0.2.0/23 | 1.0.2.0 | 1.0.3.255 |     16777728 |   16778239 |
| 1.0.4.0/22 | 1.0.4.0 | 1.0.7.255 |     16778240 |   16779263 |
+------------+---------+-----------+--------------+------------+

(tín dụng ở trên cho Blog S0BEIT sau một số bản sửa lỗi được đề cập)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. cách cập nhật giá trị hoán đổi của hai hàng với một truy vấn

  2. Làm thế nào để có được một danh sách các cơ sở dữ liệu?

  3. Chèn các chuỗi duy nhất gồm 8 ký tự ngẫu nhiên

  4. java - DataSource cho ứng dụng độc lập - không có máy chủ ứng dụng

  5. LỖI 1115 (42000):Bộ ký tự không xác định:'utf8mb4'