簡體   English   中英

具有參數語法的MySQL過程

[英]MySQL Procedure with parameter syntax

我有一個架構,其中包含來自星球大戰,出現的電影,所拜訪的行星等角色的列表。這是架構:

CREATE DATABASE  IF NOT EXISTS `starwarsFINAL` /*!40100 DEFAULT CHARACTER SET utf8 */;
USE `starwarsFINAL`;

DROP TABLE IF EXISTS `characters`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `characters` (
  `character_name` varchar(45) NOT NULL,
  `race` varchar(45) DEFAULT NULL,
  `homeworld` varchar(45) DEFAULT 'Unknown',
  `affiliation` varchar(45) DEFAULT NULL,
  PRIMARY KEY (`character_name`),
   KEY `planet_fk` (`homeworld`),
  CONSTRAINT `planet_fk` FOREIGN KEY (`homeworld`) REFERENCES `planets`     (`planet_name`) ON DELETE SET NULL ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

DROP TABLE IF EXISTS `movies`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `movies` (
  `movie_id` int(11) NOT NULL,
  `title` varchar(128) DEFAULT NULL,
  `scenes_in_db` int(11) DEFAULT NULL,
  `scenes_in_movies` int(11) DEFAULT NULL,
  PRIMARY KEY (`movie_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

DROP TABLE IF EXISTS `planets`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `planets` (
  `planet_name` varchar(45) NOT NULL,
  `planet_type` varchar(30) DEFAULT NULL,
  `affiliation` varchar(30) DEFAULT NULL,
  PRIMARY KEY (`planet_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

DROP TABLE IF EXISTS `timetable`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `timetable` (
  `character_name` varchar(45) DEFAULT NULL,
  `planet_name` varchar(45) DEFAULT 'Unknown',
  `movie_id` int(11) DEFAULT NULL,
  `arrival` int(11) DEFAULT NULL,
  `departure` int(11) DEFAULT NULL,
  `time_id` int(11) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`time_id`),
  UNIQUE KEY `timetable_un`     (`character_name`,`planet_name`,`movie_id`,`arrival`),
  KEY `timetable_fkplanet` (`planet_name`),
  KEY `timetable_fkmovie` (`movie_id`),
  CONSTRAINT `timetable_fkcharacter` FOREIGN KEY (`character_name`) REFERENCES     `characters` (`character_name`) ON DELETE CASCADE ON UPDATE CASCADE,
  CONSTRAINT `timetable_fkmovie` FOREIGN KEY (`movie_id`) REFERENCES `movies`     (`movie_id`) ON DELETE CASCADE ON UPDATE CASCADE,
  CONSTRAINT `timetable_fkplanet` FOREIGN KEY (`planet_name`) REFERENCES     `planets` (`planet_name`) ON DELETE SET NULL ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=57 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

這是我的問題:

編寫一個過程track_planet(planet) ,該過程接受一個行星名稱,並返回一個結果集,其中包含該行星名稱,電影名稱以及該電影中出現在該行星上的字符數。

到目前為止,這是我所擁有的,但是我對如何使其工作迷失了自己。 (我是MySQL的新手)

DROP PROCEDURE IF EXISTS track_planet;
DELIMITER $$
CREATE PROCEDURE track_planet(IN planet VARCHAR(45))
BEGIN
    SELECT planet_name FROM planets, title FROM movies, 
    COUNT(DISTINCT character_name) FROM characters WHERE planet_name = planet;
END
DELIMITER;

你好朋友。

首先,感謝您發布數據庫的架構,它確實有幫助。 從中我可以拍到這張照片:

在此處輸入圖片說明

而且我將您的代碼更改為此:

DELIMITER $$

DROP PROCEDURE IF EXISTS track_planet $$

CREATE PROCEDURE track_planet(IN planet VARCHAR(45))
BEGIN
    SELECT 
    tt.planet_name as planetName, m.title as movieName, COUNT(tt.character_name) as characters
    FROM timetable tt 
    LEFT JOIN movies m ON tt.movie_id = m.movie_id
    WHERE tt.planet_name = planet
    GROUP BY planetName, movieName;
END $$

DELIMITER ;

除了很少的修改外,函數聲明的代碼幾乎相同。

主要變化是SELECT語句:

  1. 選擇必要的列;
  2. 似乎您在timetable內擁有大部分信息,因此僅加入movies即可獲得電影名稱;
  3. 首先在星球名稱上使用GROUP BY ,然后在電影名稱上使用GROUP BY ,以便它將根據特定電影對特定星球上的字符進行計數

就是這樣...

希望這會有所幫助。 請讓我知道這對你有沒有用。

干杯!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM