在MYSQL中一对多表关系这样显示,最优的做法是什么?
想表达的意思:用户有很多属性(Tag),比如唱歌、跳舞、玩游戏,表结构如下图:
创建表的mysql语句如下:
drop table if exists user; create table user ( user_id int not null auto_increment, user_name varchar(20), primary key (user_id) ); drop table if exists tags; create table tags ( tag_id int not null auto_increment, tag_name varchar(100), primary key (tag_id) ); drop table if exists user_tag; create table user_tag ( user_id int, tag_id int );
插入数据的SQL语句如下:
insert into user values(1,'小A'); insert into user values(2,'小B'); insert into user values(3,'小C'); insert into tags values(1,'唱歌'); insert into tags values(2,'跳舞'); insert into tags values(3,'宅'); insert into tags values(4,'看书'); insert into tags values(5,'旅游'); insert into user_tag values(1,1); insert into user_tag values(1,2); insert into user_tag values(2,1); insert into user_tag values(3,1); insert into user_tag values(3,4); insert into user_tag values(3,5);
我想在页面表现如下:
首先是用户列表,但同时把用户的tag都带出来。
最终的表现形式和segmentfault的首页列表很像,显示问题列表并顺便把问题的很多tag也显示出来。
目前我有两种办法:
- 先把用户select出来,然后在php中循环用户的结果集,再select出属性。
- 通过join连表,查出如下的记录,然后再显示的时候过滤。
请教有没有其他的方案?
谢谢。
回复内容:
想表达的意思:用户有很多属性(Tag),比如唱歌、跳舞、玩游戏,表结构如下图:
创建表的mysql语句如下:
drop table if exists user; create table user ( user_id int not null auto_increment, user_name varchar(20), primary key (user_id) ); drop table if exists tags; create table tags ( tag_id int not null auto_increment, tag_name varchar(100), primary key (tag_id) ); drop table if exists user_tag; create table user_tag ( user_id int, tag_id int );
插入数据的SQL语句如下:
insert into user values(1,'小A'); insert into user values(2,'小B'); insert into user values(3,'小C'); insert into tags values(1,'唱歌'); insert into tags values(2,'跳舞'); insert into tags values(3,'宅'); insert into tags values(4,'看书'); insert into tags values(5,'旅游'); insert into user_tag values(1,1); insert into user_tag values(1,2); insert into user_tag values(2,1); insert into user_tag values(3,1); insert into user_tag values(3,4); insert into user_tag values(3,5);
我想在页面表现如下:
首先是用户列表,但同时把用户的tag都带出来。
最终的表现形式和segmentfault的首页列表很像,显示问题列表并顺便把问题的很多tag也显示出来。
目前我有两种办法:
- 先把用户select出来,然后在php中循环用户的结果集,再select出属性。
- 通过join连表,查出如下的记录,然后再显示的时候过滤。
请教有没有其他的方案?
谢谢。
如果数据量不大,那么使用left join 即可,很多企业级的产品基本采用这种方式。
如果数据量比较大,那么需要采用冷热数据,热数据把uid uname tag_name这放到缓存中,冷数据采用多个简单查询方式。
你说的两种方法里的1比较好,很多网站也是这么做的。
但是有一点,就是user_tag
表要做一层缓存,让全部的这种user-tag的查询都到内存中进行。
if you don't need to lookup users by tag, i will simply put all of them into one table. managing user_tag will be a pain later on. it will also be easier if you have a max on the number of tags a user can have ...
这是一个多对多关系把??

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。

Passwordが暗号化された形式で保存されているため、MariadbのNavicatはデータベースパスワードを直接表示できません。データベースのセキュリティを確保するには、パスワードをリセットするには3つの方法があります。NAVICATを介してパスワードをリセットし、複雑なパスワードを設定します。構成ファイルを表示します(推奨されていない、高リスク)。システムコマンドラインツールを使用します(推奨されません。コマンドラインツールに習熟する必要があります)。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLでテーブルをコピーするには、新しいテーブルの作成、データの挿入、外部キーの設定、インデックスのコピー、トリガー、ストアドプロシージャ、および機能が必要です。特定の手順には、同じ構造を持つ新しいテーブルの作成が含まれます。元のテーブルからデータを新しいテーブルに挿入します。同じ外部キーの制約を設定します(元のテーブルに1つがある場合)。同じインデックスを作成します。同じトリガーを作成します(元のテーブルに1つがある場合)。同じストアドプロシージャまたは関数を作成します(元のテーブルが使用されている場合)。

データベースに接続するときの一般的なエラーとソリューション:ユーザー名またはパスワード(エラー1045)ファイアウォールブロック接続(エラー2003)接続タイムアウト(エラー10060)ソケット接続を使用できません(エラー1042)SSL接続エラー(エラー10055)接続の試みが多すぎると、ホストがブロックされます(エラー1129)データベースは存在しません(エラー1049)

手順に従って、NAVICATで新しいMySQL接続を作成できます。アプリケーションを開き、新しい接続(CTRL N)を選択します。接続タイプとして「mysql」を選択します。ホスト名/IPアドレス、ポート、ユーザー名、およびパスワードを入力します。 (オプション)Advanced Optionsを構成します。接続を保存して、接続名を入力します。
