Maison >développement back-end >tutoriel php >Utilisez PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise

Utilisez PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise

PHPz
PHPzoriginal
2023-08-07 15:34:42766parcourir

Utilisez PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise

Utilisez PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise

Résumé : Cet article présente comment utiliser les moteurs de recherche PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise. En créant l'interface de gestion et l'interface de recherche, et en configurant coreseek, les développeurs peuvent facilement mettre en œuvre un système de recherche de connaissances médicales efficace et flexible.

Mots clés : PHP, coreseek, recherche de connaissances médicales, moteur de recherche

Introduction : Avec le développement rapide d'Internet, la demande de connaissances médicales est également de plus en plus élevée. Afin de répondre aux besoins des utilisateurs, nous espérons développer un système de recherche de connaissances médicales efficace et flexible. Parmi les nombreux moteurs de recherche, coreseek est un choix très populaire. Cet article expliquera comment utiliser PHP et coreseek pour implémenter une fonction de recherche de connaissances médicales précise.

Première partie : Création de l'interface de gestion

Tout d'abord, nous devons créer une interface de gestion afin que les administrateurs puissent facilement ajouter, modifier et supprimer des données de connaissances médicales. Nous pouvons utiliser PHP pour développer une interface de gestion simple, comprenant les fonctions suivantes :

  1. Ajouter des connaissances médicales : Les administrateurs peuvent ajouter le titre, le contenu et d'autres informations des connaissances médicales sur l'interface de gestion.
  2. Modifier les connaissances médicales : Les administrateurs peuvent modifier les connaissances médicales existantes sur l'interface de gestion.
  3. Supprimer les connaissances médicales : Les administrateurs peuvent supprimer les connaissances médicales existantes sur l'interface de gestion.

Voici un exemple de code PHP simple pour implémenter la fonction ci-dessus :

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "medical_knowledge";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("连接失败:" . $conn->connect_error);
}

// 添加医疗知识
if (isset($_POST['add'])) {
    $title = $_POST['title'];
    $content = $_POST['content'];
    
    $sql = "INSERT INTO knowledge (title, content) VALUES ('$title', '$content')";
    if ($conn->query($sql) === TRUE) {
        echo "添加成功!";
    } else {
        echo "添加失败:" . $conn->error;
    }
}

// 编辑医疗知识
if (isset($_POST['edit'])) {
    $id = $_POST['id'];
    $title = $_POST['title'];
    $content = $_POST['content'];
    
    $sql = "UPDATE knowledge SET title='$title', content='$content' WHERE id=$id";
    if ($conn->query($sql) === TRUE) {
        echo "编辑成功!";
    } else {
        echo "编辑失败:" . $conn->error;
    }
}

// 删除医疗知识
if (isset($_GET['delete'])) {
    $id = $_GET['delete'];
    
    $sql = "DELETE FROM knowledge WHERE id=$id";
    if ($conn->query($sql) === TRUE) {
        echo "删除成功!";
    } else {
        echo "删除失败:" . $conn->error;
    }
}

// 查询医疗知识
$sql = "SELECT * FROM knowledge";
$result = $conn->query($sql);
?>

<!-- 管理界面 HTML -->
<!DOCTYPE html>
<html>
<head>
    <title>医疗知识管理</title>
</head>
<body>
    <h1>医疗知识管理</h1>

    <!-- 添加医疗知识表单 -->
    <h2>添加医疗知识</h2>
    <form action="" method="POST">
        标题:<input type="text" name="title"><br>
        内容:<textarea name="content"></textarea><br>
        <input type="submit" name="add" value="添加">
    </form>

    <!-- 编辑医疗知识表单 -->
    <h2>编辑医疗知识</h2>
    <form action="" method="POST">
        <?php while($row = $result->fetch_assoc()): ?>
        ID:<input type="text" name="id" value="<?php echo $row['id']; ?>"><br>
        标题:<input type="text" name="title" value="<?php echo $row['title']; ?>"><br>
        内容:<textarea name="content"><?php echo $row['content']; ?></textarea><br>
        <input type="submit" name="edit" value="编辑">
        <a href="?delete=<?php echo $row['id']; ?>">删除</a><br>
        <?php endwhile; ?>
    </form>
</body>
</html>

<?php
// 关闭数据库连接
$conn->close();
?>

Partie 2 : Construire une interface de recherche

Une fois que l'administrateur a configuré les connaissances médicales, nous devons développer une interface de recherche afin que les utilisateurs puissent utiliser des mots-clés rechercher des connaissances médicales pertinentes. Nous pouvons également utiliser PHP pour développer une interface de recherche simple, comprenant les fonctions suivantes :

  1. Rechercher des connaissances médicales : les utilisateurs peuvent saisir des mots-clés sur l'interface de recherche et effectuer une recherche en cliquant sur le bouton de recherche.
  2. Afficher les résultats de la recherche : les résultats de la recherche seront affichés sur l'interface de recherche sous la forme d'une liste, comprenant les titres et le contenu correspondants.

Voici un exemple de code PHP simple pour implémenter la fonctionnalité ci-dessus :

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "medical_knowledge";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("连接失败:" . $conn->connect_error);
}

// 搜索医疗知识
if (isset($_GET['search'])) {
    $keyword = $_GET['keyword'];
    
    // 调用coreseek搜索引擎
    $searchCmd = "/usr/local/coreseek/bin/search -i index -c /usr/local/coreseek/etc/csft.conf -q "$keyword" -n 0,20";
    exec($searchCmd, $output);
    
    // 显示搜索结果
    echo "<h2>搜索结果</h2>";
    foreach ($output as $result) {
        $resultArray = explode("    ", $result);
        $title = $resultArray[0];
        $content = $resultArray[1];
        
        echo "<h3>$title</h3>";
        echo "<p>$content</p>";
    }
}
?>

<!-- 搜索界面 HTML -->
<!DOCTYPE html>
<html>
<head>
    <title>医疗知识搜索</title>
</head>
<body>
    <h1>医疗知识搜索</h1>

    <!-- 搜索表单 -->
    <form action="" method="GET">
        <input type="text" name="keyword">
        <input type="submit" name="search" value="搜索">
    </form>
</body>
</html>

<?php
// 关闭数据库连接
$conn->close();
?>

Partie 3 : Configuration de coreseek

Pour que coreseek et PHP fonctionnent correctement, nous devons d'abord effectuer une configuration. Tout d'abord, nous devons créer le fichier de configuration de coreseek /usr/local/coreseek/etc/csft.conf et ajouter le contenu suivant dans le fichier :

source medical_knowledge
{
    type                    = mysql
    sql_host                = localhost
    sql_user                = username
    sql_pass                = password
    sql_db                  = medical_knowledge
    sql_port                = 3306

    sql_query               = SELECT id, title, content FROM knowledge
    sql_attr_uint           = id
    sql_attr_str2ordinal    = title
    sql_attr_str2ordinal    = content
}

index index
{
    source                  = medical_knowledge
    path                    = /usr/local/coreseek/var/data/medical_knowledge
    min_word_len            = 1
    min_prefix_len          = 1
    enable_star             = 1
}

searchd
{
    listen                  = 9312
    log                     = /usr/local/coreseek/var/log/searchd.log
    query_log               = /usr/local/coreseek/var/log/query.log
    read_timeout            = 5
    max_children            = 30
    pid_file                = /usr/local/coreseek/var/log/searchd.pid
    seamless_rotate         = 0
    preopen_indexes         = 0
    unlink_old              = 1
}

Ensuite, nous devons créer un index pour coreseek afin d'effectuer des recherches correspondantes. Ouvrez un terminal et exécutez la commande suivante :

$ /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all

Enfin, nous devons démarrer le service de recherche de coreseek. Exécutez la commande suivante dans le terminal :

$ /usr/local/coreseek/bin/searchd -c /usr/local/coreseek/etc/csft.conf

Conclusion : Grâce aux étapes ci-dessus, nous avons réussi à implémenter une fonction de recherche de connaissances médicales précise à l'aide de PHP et coreseek. Les administrateurs peuvent ajouter, modifier et supprimer des connaissances médicales via l'interface de gestion, et les utilisateurs peuvent rechercher des connaissances médicales pertinentes via l'interface de recherche. En configurant les services d'indexation et de recherche de coreseek, nous avons mis en œuvre un système de recherche de connaissances médicales efficace et flexible.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn