Rumah >pangkalan data >tutorial mysql >Bagaimana untuk melaksanakan fungsi navigasi peta mudah menggunakan MySQL dan Ruby

Bagaimana untuk melaksanakan fungsi navigasi peta mudah menggunakan MySQL dan Ruby

王林
王林asal
2023-09-21 16:23:071043semak imbas

Bagaimana untuk melaksanakan fungsi navigasi peta mudah menggunakan MySQL dan Ruby

Cara menggunakan MySQL dan Ruby untuk melaksanakan fungsi navigasi peta yang mudah

Dalam masyarakat moden, fungsi navigasi peta telah menjadi bahagian yang amat diperlukan dalam kehidupan manusia. Sama ada mengembara, mengembara atau mencari tempat tertentu, navigasi peta boleh membantu kami mencari destinasi kami dengan cepat dan tepat. Artikel ini akan memperkenalkan cara menggunakan bahasa MySQL dan Ruby untuk melaksanakan fungsi navigasi peta yang mudah.

Pertama, kita perlu mencipta pangkalan data untuk menyimpan data peta. Menggunakan pangkalan data MySQL adalah pilihan yang baik kerana MySQL ialah sistem pengurusan pangkalan data hubungan sumber terbuka yang mempunyai ciri-ciri kestabilan tinggi, prestasi unggul dan kemudahan penggunaan.

Dalam MySQL, kita boleh mencipta pangkalan data yang dipanggil "peta" dan mencipta dua jadual di dalamnya, "lokasi" dan "laluan". "Lokasi" jadual digunakan untuk menyimpan maklumat lokasi, termasuk nama lokasi, longitud, latitud, dll., "laluan" jadual digunakan untuk menyimpan maklumat laluan antara dua lokasi, termasuk titik permulaan, titik akhir, jarak, dsb .

Berikut ialah contoh pernyataan SQL untuk mencipta jadual "lokasi":

CREATE TABLE locations (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    latitude DECIMAL(9, 6) NOT NULL,
    longitude DECIMAL(9, 6) NOT NULL
);

Berikut ialah contoh pernyataan SQL untuk mencipta jadual "laluan":

CREATE TABLE routes (
    id INT PRIMARY KEY AUTO_INCREMENT,
    start_location_id INT NOT NULL,
    end_location_id INT NOT NULL,
    distance DECIMAL(9, 2) NOT NULL,
    FOREIGN KEY (start_location_id) REFERENCES locations(id),
    FOREIGN KEY (end_location_id) REFERENCES locations(id)
);

Seterusnya, kita boleh menggunakan bahasa Ruby untuk tulis kod untuk fungsi navigasi peta. Pertama, kita perlu memasang pemacu MySQL Ruby, yang boleh dipasang menggunakan arahan permata:

gem install mysql2

Kemudian, dalam kod Ruby, kita perlu menggunakan objek sambungan MySQL dan objek pertanyaan untuk melaksanakan operasi pangkalan data. Berikut ialah contoh kod yang menggunakan Ruby untuk menyambung ke pangkalan data MySQL dan menanyakan semua maklumat lokasi:

require 'mysql2'

client = Mysql2::Client.new(
    host: 'localhost',
    username: 'root',
    password: 'password',
    database: 'maps'
)

results = client.query('SELECT * FROM locations')

results.each do |row|
    puts "ID: #{row['id']}, Name: #{row['name']}, Latitude: #{row['latitude']}, Longitude: #{row['longitude']}"
end

client.close

Kod di atas mula-mula mencipta objek sambungan MySQL, dan kemudian menggunakan objek sambungan untuk melaksanakan pernyataan pertanyaan untuk menanyakan jadual " lokasi" Semua data dan mencetak hasil pertanyaan. Akhirnya, sambungan pangkalan data ditutup.

Seterusnya, kita boleh melaksanakan fungsi navigasi peta. Berikut ialah contoh kod mudah untuk menanyakan laluan terpendek berdasarkan titik mula dan tamat:

require 'mysql2'
require 'dijkstra'

client = Mysql2::Client.new(
    host: 'localhost',
    username: 'root',
    password: 'password',
    database: 'maps'
)

routes = client.query('SELECT * FROM routes')
locations = Hash.new

routes.each do |row|
    start_location_id = row['start_location_id']
    end_location_id = row['end_location_id']
    distance = row['distance']

    locations[start_location_id] ||= Hash.new
    locations[start_location_id][end_location_id] = distance
end

graph = Dijkstra::Graph.new(locations)

shortest_path = graph.shortest_path(start_location_id, end_location_id)

shortest_distance = shortest_path.distance
shortest_path.each do |location_id|
    location = client.query("SELECT * FROM locations WHERE id = #{location_id}").first
    puts "#{location['name']}: #{location['latitude']}, #{location['longitude']}"
end

puts "Shortest Distance: #{shortest_distance}"

client.close

Kod di atas mula-mula mencipta "lokasi" jadual cincang kosong untuk menyimpan maklumat jarak antara lokasi. Kemudian, jadual cincang diisi berdasarkan hasil pertanyaan. Seterusnya, gunakan algoritma Dijkstra untuk mengira laluan terpendek, dan mencetak maklumat lokasi dan jarak laluan terpendek.

Melalui operasi di atas, kami telah melaksanakan fungsi navigasi peta yang mudah. Sudah tentu, artikel ini hanya menyediakan idea pelaksanaan awal Fungsi navigasi peta sebenar memerlukan reka bentuk dan pembangunan yang lebih terperinci berdasarkan keperluan sebenar. Saya harap artikel ini dapat memberikan sedikit rujukan dan bantuan untuk menggunakan MySQL dan Ruby untuk melaksanakan fungsi navigasi peta.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi navigasi peta mudah menggunakan MySQL dan Ruby. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Artikel berkaitan

Lihat lagi