Home Database Mysql Tutorial 数据库设计问题 – SQL_MySQL

数据库设计问题 – SQL_MySQL

Jun 01, 2016 pm 01:51 PM
Database Design

要求:a 表:`id`, `name` ; 作为词表,存放不同的词;b 表:`id`, `attr` ; 作为属性表,存放各种属性;其中,一个词可以有不同的多个属性;而每个词的属性的个数也不一定相同;c 表:`id`, `aid`, `bid` ; 作为关系表,存放每个词的对应关系;写出 SQL 语句,来得到每个词拥有属性总数的逆向(DESC)排序:

各种表的信息如下:

mysql> DESC `a`; DESC `b`; DESC `c`;+-------+---------------------+------+-----+---------+----------------+| Field | Type                | Null | Key | Default | Extra          |+-------+---------------------+------+-----+---------+----------------+| id    | bigint(20) unsigned | NO   | PRI | NULL    | auto_increment || name  | varchar(255)        | NO   |     | NULL    |                |+-------+---------------------+------+-----+---------+----------------+2 rows in set (0.00 sec)+-------+---------------------+------+-----+---------+----------------+| Field | Type                | Null | Key | Default | Extra          |+-------+---------------------+------+-----+---------+----------------+| id    | bigint(20) unsigned | NO   | PRI | NULL    | auto_increment || attr  | varchar(255)        | NO   |     | NULL    |                |+-------+---------------------+------+-----+---------+----------------+2 rows in set (0.01 sec)+-------+---------------------+------+-----+---------+----------------+| Field | Type                | Null | Key | Default | Extra          |+-------+---------------------+------+-----+---------+----------------+| id    | bigint(20) unsigned | NO   | PRI | NULL    | auto_increment || aid   | int(8)              | NO   |     | NULL    |                || bid   | int(8)              | NO   |     | NULL    |                |+-------+---------------------+------+-----+---------+----------------+3 rows in set (0.00 sec)
Copy after login

我们预先放入测试的数据,如下:

mysql> SELECT * FROM `a`; SELECT * FROM `b`; SELECT * FROM `c`;+----+------+| id | name |+----+------+|  1 | a    ||  2 | b    ||  3 | c    ||  4 | d    ||  5 | e    |+----+------+5 rows in set (0.00 sec)+----+------+| id | attr |+----+------+|  1 | 111  ||  2 | 112  ||  3 | 113  ||  4 | 123  ||  5 | 221  ||  6 | 231  ||  7 | 252  ||  8 | 278  ||  9 | 292  || 10 | 256  || 11 | 578  || 12 | 653  || 13 | 521  || 14 | 502  |+----+------+14 rows in set (0.00 sec)+----+-----+-----+| id | aid | bid |+----+-----+-----+|  1 |   1 |   1 ||  2 |   1 |   2 ||  3 |   1 |   4 ||  4 |   1 |   7 ||  5 |   2 |   8 ||  6 |   2 |  11 ||  7 |   3 |   3 ||  8 |   3 |   5 ||  9 |   3 |   6 || 10 |   4 |   9 || 11 |   4 |  10 || 12 |   5 |  12 || 13 |   5 |  13 || 14 |   5 |  14 |+----+-----+-----+14 rows in set (0.00 sec)
Copy after login

首先执行下列语句:

mysql> SELECT COUNT(`bid`) AS `attrcounts` FROM `c` GROUP BY `aid` ORDER BY `attrcounts` DESC;+------------+| attrcounts |+------------+|          4 ||          3 ||          3 ||          2 ||          2 |+------------+5 rows in set (0.00 sec)
Copy after login

进而,我们再连表:

mysql> SELECT a.name, COUNT(c.bid) AS `attrcounts` FROM `c` LEFT JOIN `a` ON a.id = c.aid GROUP BY c.aid ORDER BY `attrcounts` DESC;+------+------------+| name | attrcounts |+------+------------+| a    |          4 || c    |          3 || e    |          3 || b    |          2 || d    |          2 |+------+------------+5 rows in set (0.00 sec)
Copy after login

于是,我们得到了结果;

-------

补充一些基础知识:

如何修改已有表的列:http://www.w3school.com.cn/sql/sql_alter.asp

GROUP BY 相关知识:http://www.w3school.com.cn/sql/sql_groupby.asp

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Have Crossplay?
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Redundant Field Issues in Database Design: Best Practices in PHP Programming Redundant Field Issues in Database Design: Best Practices in PHP Programming Jun 22, 2023 am 11:02 AM

With the popularity of the Internet and the increasing number of application scenarios, database design has become an extremely important issue. In database design, redundant fields are a very important issue. Redundant fields refer to duplicate or unnecessary fields that appear when designing the database. Although redundant fields can improve query efficiency and speed to a certain extent, they also waste storage space, increase maintenance difficulty, and even affect data consistency and security. Therefore, in PHP programming, certain best practices should be followed to solve the problems caused by redundant fields.

Research on solutions to database design problems encountered in development using MongoDB technology Research on solutions to database design problems encountered in development using MongoDB technology Oct 08, 2023 pm 05:53 PM

Exploring solutions to database design problems encountered in the development of MongoDB technology Abstract: With the rapid development of big data and cloud computing, database design is particularly important in software development. This article will discuss common database design issues encountered during development and introduce MongoDB solutions through specific code examples. Introduction: In the software development process, database design is a key link. Traditional relational databases have some performance and scalability issues when processing large-scale data. And MongoD

Golang learning database design practice for web applications Golang learning database design practice for web applications Jun 24, 2023 am 10:33 AM

Golang is a programming language developed by Google. Its simplicity of use, superior performance, and cross-platform features make it increasingly popular in modern web application development. In web application development, database design is a very important part. In this article, we will introduce how to practice database design when developing web applications using Golang. Choosing a database First, we need to choose a suitable database. Golang supports a variety of databases, such as MySQL, Po

How to implement database design for multi-specification SKU of products in PHP How to implement database design for multi-specification SKU of products in PHP Sep 06, 2023 am 09:03 AM

How to implement database design for product multi-specification SKU in PHP In e-commerce platforms, product specifications are a very important concept. Product specifications can be understood as the different attributes and characteristics of the product, such as size, color, weight, etc. In practical applications, for different specifications, we often need to set different prices, inventory, pictures and other information for each combination. This requires us to design a suitable database structure to store and manage product specifications and related information. This article will introduce how to implement multi-specification SKU of products in PHP

MySQL database design: ordering system menu table MySQL database design: ordering system menu table Nov 01, 2023 pm 12:40 PM

MySQL database design: ordering system menu list Introduction: In the catering industry, the design and implementation of the ordering system is crucial. One of the core data tables is the menu table. This article will introduce in detail how to design and create an effective menu table to support the functions of the ordering system. 1. Requirements analysis Before designing the menu list, we need to clarify the requirements and functions of the system. In the ordering system, the menu table needs to store relevant information about each dish, including dish name, price, classification, description, etc. In addition, you also need to consider the dishes

Use MySQL MVCC to optimize database design and improve application performance Use MySQL MVCC to optimize database design and improve application performance Sep 08, 2023 am 08:34 AM

Use MySQLMVCC to optimize database design and improve application performance Summary: In today's Internet applications, database performance is crucial to the stable operation and response time of the system. As one of the most commonly used relational database management systems, MySQL uses multi-version concurrency control (MVCC) to improve concurrency performance and data consistency when designing the database. This article will introduce the basic principles of MVCC and its implementation in MySQL, and give some examples of optimizing database design. Basic principles of MVCC multi-version concurrency

Design and application of PHP and MySQL databases Design and application of PHP and MySQL databases Jun 20, 2023 am 09:27 AM

PHP and MySQL are a powerful pair with a wide range of applications. In the Internet industry, PHP and MySQL have become the standard configuration of the technology stack, and a large number of websites, web applications, backend management systems and other applications have adopted this combination. This article will explore the design and application of PHP and MySQL databases and introduce some best practices. 1. Advantages of PHP and MySQL database PHP is an open source, cross-platform, server-side Web programming language with a wide range of application scenarios. MySQL is a

Detailed explanation of the application of MySQL composite primary key in database design Detailed explanation of the application of MySQL composite primary key in database design Mar 15, 2024 am 11:33 AM

Detailed explanation of the application of MySQL composite primary key in database design MySQL composite primary key refers to a primary key composed of multiple fields. A record is uniquely identified by combining the values ​​of these fields. In database design, composite primary keys are widely used, especially when an entity needs to be uniquely identified. This article will introduce in detail the concept, design principles and specific code examples of MySQL composite primary keys. 1. The concept of MySQL composite primary key. In MySQL, the primary key is a field used to uniquely identify each row of data in the table.

See all articles