>  기사  >  데이터 베이스  >  MySQL과 Ruby를 사용하여 간단한 투표 시스템을 구현하는 방법

MySQL과 Ruby를 사용하여 간단한 투표 시스템을 구현하는 방법

WBOY
WBOY원래의
2023-09-20 12:37:511061검색

MySQL과 Ruby를 사용하여 간단한 투표 시스템을 구현하는 방법

MySQL 및 Ruby를 사용하여 간단한 투표 시스템을 구현하는 방법

투표 시스템은 이슈나 주제에 대한 사용자 의견을 수집하는 데 사용되는 일반적인 온라인 애플리케이션입니다. 이 기사에서는 MySQL 데이터베이스와 Ruby 프로그래밍 언어를 사용하여 간단한 투표 시스템을 구현하는 방법을 소개합니다.

먼저 환경을 준비해야 합니다. MySQL 데이터베이스를 설치했고 Ruby 프로그래밍 환경을 갖추고 있는지 확인하세요. 아직 설치되지 않은 경우 공식 홈페이지에서 다운로드한 후 안내에 따라 설치하시면 됩니다.

다음으로 데이터베이스를 만들어야 합니다. MySQL 터미널을 열거나 그래픽 인터페이스 도구(예: PhpMyAdmin)를 사용하여 "voting_system"이라는 빈 데이터베이스를 만듭니다. 투표 정보를 저장하려면 이 데이터베이스 아래에 "votes"라는 테이블을 만듭니다. 테이블에는 다음 필드가 포함되어야 합니다.

  • id: 기본 키로 자동 증가하는 정수 유형
  • question: 투표 질문의 텍스트 유형
  • option1: 첫 번째 옵션의 텍스트 유형
  • option2: 두 번째 옵션의 텍스트 유형
  • option1_votes: 첫 번째 옵션인 정수형에 대한 투표 수, 기본값은 0
  • option2_votes: 두 번째 옵션인 정수 유형에 대한 투표 수, 기본값은 0

다음을 실행하세요. 테이블을 생성하기 위한 MySQL의 SQL 문:

CREATE TABLE votes (
  id INT PRIMARY KEY AUTO_INCREMENT,
  question TEXT,
  option1 TEXT,
  option2 TEXT,
  option1_votes INT DEFAULT 0,
  option2_votes INT DEFAULT 0
);

다음으로 Ruby를 사용하여 데이터베이스에 연결하고 투표 시스템의 기능을 구현해 보겠습니다. 먼저 Ruby의 MySQL 드라이버 gem을 설치해야 합니다. 설치하려면 명령줄에서 다음 명령을 실행하세요.

gem install mysql2

그런 다음 "voting_system.rb"와 같은 Ruby 파일을 만들고 다음 코드를 사용하여 MySQL 데이터베이스에 연결합니다.

require 'mysql2'

# 创建数据库连接
client = Mysql2::Client.new(:host => "localhost", :username => "root", :password => "your-password", :database => "voting_system")

# 添加投票
def add_vote(question, option1, option2)
  query = "INSERT INTO votes (question, option1, option2) VALUES ('#{question}', '#{option1}', '#{option2}')"
  client.query(query)
  puts "投票问题:#{question},选项1:#{option1},选项2:#{option2},已添加"
end

# 获取投票信息
def get_votes
  query = "SELECT * FROM votes"
  result = client.query(query)
  result.each do |row|
    puts "投票ID: #{row['id']}"
    puts "问题: #{row['question']}"
    puts "选项1: #{row['option1']}"
    puts "选项1票数: #{row['option1_votes']}"
    puts "选项2: #{row['option2']}"
    puts "选项2票数: #{row['option2_votes']}"
    puts "
"
  end
end

# 投票
def vote(vote_id, option)
  query = "UPDATE votes SET #{option}_votes = #{option}_votes + 1 WHERE id = #{vote_id}"
  client.query(query)
  puts "投票ID:#{vote_id},选项:#{option},已记录"
end

# 示例代码
add_vote("你喜欢吃水果吗?", "喜欢", "不喜欢")
get_votes
vote(1, "option1")
get_votes

위의 예제 코드에서, 우리는 투표 시스템의 기능을 구현하기 위한 몇 가지 방법을 정의했습니다. "add_vote" 메소드는 투표 질문과 옵션을 데이터베이스에 추가하는 데 사용되고, "get_votes" 메소드는 데이터베이스의 모든 투표 정보를 얻는 데 사용되며, "vote" 메소드는 사용자의 투표 선택을 기록하는 데 사용됩니다.

"voting_system.rb" 파일을 저장하고 실행하면 콘솔에 인쇄된 투표 정보를 볼 수 있으며, 투표 데이터가 업데이트됩니다.

위 단계를 통해 MySQL 데이터베이스와 Ruby 프로그래밍 언어를 사용하여 간단한 투표 시스템을 성공적으로 구현했습니다. 더 많은 옵션, 투표 통계 등을 추가하는 등 필요에 따라 코드를 수정하고 확장할 수 있습니다. 이 기사가 도움이 되기를 바랍니다!

위 내용은 MySQL과 Ruby를 사용하여 간단한 투표 시스템을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.