ホームページ データベース mysql チュートリアル 数据库字段复用的基本原理与示例_MySQL

数据库字段复用的基本原理与示例_MySQL

Jun 01, 2016 pm 01:50 PM
バイナリ 使用

bitsCN.com

  一、逻辑代数基础:

  1,数字用二进制表示,所有可能出现的数只有0和1两个。

  2,基本运算只有“与”、“或”、“非”三种。

  与运算定义为:(用 & 表示与运算)

  0 & 0 = 0

  0 & 1 = 0

  1 & 0 = 0

  1 & 1 = 1

  可以简单理解为:只要有一个0,结果就是0,和乘法类似。

  或运算定义为:(用 | 表示与运算)

  0 | 0 = 0

  0 | 1 = 1

  1 | 0 = 1

  1 | 1 = 1

  可以简单理解为:只要有一个1,结果就是1,和加法类似。

  二、逻辑运算示例:

  01111010101010101111111111111111 & 1100000 = 1100000

  一般可以理解为:

  如果要获取一个数字某N位的数值,只需要将这个数字与2的N-1次方(掩码)进行与运算即可。

  三、数据库字段定义:

  以数据表 binary_sample为例:

  create table binary_sample(

  uid int unsigned not null,

  status int unsigned not null default 0,

  primary key(uid),

  key i_s(status)

  )engine=innodb;

  status字段定义:

  status字段数据类型为32bit的整数,为了尽可能的存储多个属性,我们将其进行如下定义:

  以下所有“位”的描述顺序按照从低到高(从右到左)顺序表示。

  0-2位表示用户注册状态:

  000 表示新注册未被批准

  001 表示注册被批准

  010 表示位高级用户

  011 表示管理员

  100 表示超级管理员

  101 保留

  110 保留

  111 掩码

  3-5位用户性别:

  000 表示性别不确定

  001 表示性别为男

  010 表示性别为女

  011 保留

  100 保留

  101 保留

  110 保留

  111 掩码

  如果我们要查询所有 男用户 则:

  select * from binary_sample where status & b'111000' = b'001000';

  如果我们要查询所有 管理员用户 则:

  select * from binary_sample where status & b'111' = b'011';

  如果我们要查询所有 男管理员用户 则:

  select * from binary_sample where status & b'111111' = b'001011';

  如果我们要查询所有 非 新注册未被批准用户 则:

  select * from binary_sample where status & b'111' != b'000';

  四,使用PHP程序进行此类计算:

  define("USER_NEW",0);//000

  define("USER_NORMAL",1);//001

  define("USER_ADVANCE",2);//010

  define("USER_MANAGE",3);//011

  define("USER_SUPER",4);//100

  define("USER_MASK",7);//111

  define("GENDER_UNKNOWN",0);// 000000

  define("GENDER_MALE",8);// 001000

  define("GENDER_FEMALE",9);// 010000

  define("GENDER_MASK",56);// 111000

  如果我们要查询所有 男用户 则:

  $status=GENDER_MALE;

  $mask=GENDER_MASK;

  $sql="select * from binary_sample where status & ${mask}' = ${status}";

  如果我们要查询所有 管理员用户 则:

  $status=USER_MANAGE;

  $mask=USER_MASK;

  $sql="select * from binary_sample where status & ${mask}' = ${status}";

  如果我们要查询所有 男管理员用户 则:

  $status=GENDER_MALE & USER_MANAGE;

  $mask = GENDER_MASK & GENDER_MASK;

  $sql="select * from binary_sample where status & ${mask}' = ${status}";

  如果我们要查询所有 非 新注册未被批准用户 则:

  $status = USER_NEW;

  $mask = USER_MASK;

  $sql="select * from binary_sample where status & ${mask} != ${status}";

  依此类推,只要定义好每个值的含义,查询基本上就定了。

bitsCN.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

二進数の計算方法 二進数の計算方法 Jan 19, 2024 pm 04:38 PM

2 進数演算は 2 進数に基づいた演算方法であり、その基本演算には加算、減算、乗算、除算が含まれます。 2 進算術には、基本的な演算に加えて、論理演算、変位演算、その他の演算も含まれます。論理演算には AND、OR、NOT などの演算が含まれ、変位演算には左シフト演算と右シフト演算が含まれます。これらの操作には、対応するルールとオペランド要件があります。

C言語を使用して2進数を16進数に変換するにはどうすればよいですか? C言語を使用して2進数を16進数に変換するにはどうすればよいですか? Sep 01, 2023 pm 06:57 PM

2 進数は 1 と 0 で表されます。 16 ビットの 16 進数体系は、2 進表現から 16 進表現に変換するために、{0,1,2,3…..9,A(10),B(11),…F(15)} となります。文字列 ID は、最下位側から始まるニブルと呼ばれる 4 ビットのチャンクにグループ化されます。各ブロックは、対応する 16 進数に置き換えられます。 16 進数と 2 進数の表現を明確に理解するために例を見てみましょう。 001111100101101100011101 3 E 5 B&N

EDVAC の 2 つの主な改良点は何ですか? EDVAC の 2 つの主な改良点は何ですか? Mar 02, 2023 pm 02:58 PM

EDVAC には 2 つの大きな改良点があります。1 つはバイナリの使用、もう 1 つは保存されたプログラムの完成です。これは、あるプログラム命令から次のプログラム命令に自動的に進み、その操作は命令を通じて自動的に完了できます。 「命令」にはデータやプログラムが含まれており、それらはコードの形で機械の記憶装置に入力されます、つまり、データを格納する同じ記憶装置を使用して、演算を実行するための命令を格納するという新しい概念です。 - 保存されたプログラムと呼ばれます。

Golang でバイナリ ファイルを読み取るにはどうすればよいですか? Golang でバイナリ ファイルを読み取るにはどうすればよいですか? Mar 21, 2024 am 08:27 AM

Golang でバイナリ ファイルを読み取るにはどうすればよいですか?バイナリ ファイルは、コンピュータが認識して処理できるデータを含む、バイナリ形式で保存されたファイルです。 Golang では、いくつかのメソッドを使用してバイナリ ファイルを読み取り、必要なデータ形式に解析できます。 Golangでバイナリファイルを読み込む方法と具体的なコード例を紹介します。まず、OS パッケージの Open 関数を使用してバイナリ ファイルを開く必要があります。これにより、ファイル オブジェクトが返されます。それから私たちは作ることができます

Golang はバイナリ ファイルを扱えますか? Golang はバイナリ ファイルを扱えますか? Mar 20, 2024 pm 04:36 PM

Golang はバイナリ ファイルを扱えますか? Go 言語では、バイナリ ファイルの処理は非常に一般的で便利です。組み込みのパッケージとメソッドを使用することで、バイナリ ファイルの読み取り、書き込み、操作を簡単に行うことができます。この記事では、Go でバイナリ ファイルを処理する方法を説明し、具体的なコード例を示します。バイナリ ファイルの読み取り バイナリ ファイルを読み取るには、まずファイルを開いて、対応するファイル オブジェクトを作成する必要があります。次に、Read メソッドを使用してファイルからデータを読み取り、それをバイト単位で保存します。

Go 言語で 16 進数を 2 進数に変換する方法を簡単に学習します Go 言語で 16 進数を 2 進数に変換する方法を簡単に学習します Mar 15, 2024 pm 04:45 PM

タイトル: Go 言語で 16 進数を 2 進数に変換する方法を簡単に学習します。特定のコード例が必要です。コンピューター プログラミングでは、異なる基数間の変換操作がよく使用されます。その中でも、16 進数と 2 進数間の変換は比較的一般的です。 Go 言語では、いくつかの簡単なコード例を通じて 16 進数から 2 進数への変換を実現できます。一緒に学びましょう。まずは16進数と2進数の表現方法を見てみましょう。 16 進数は数値を表す方法で、0 ~ 9 と A ~ F を使用して 1 を表します。

C++ では、2 進数の 1 ビットを削除して最大値を取得します。 C++ では、2 進数の 1 ビットを削除して最大値を取得します。 Sep 17, 2023 pm 03:53 PM

2 進数が与えられた問題について話し合います。残りの数値が他のすべてのオプションの中で最大になるように、そこから少し削除する必要があります。次のようなものです。 入力:N=1011出力:111説明:Weneedtoremoveonebitsoremoving0bitwillgiveamamaximumnumberthanremovingany1’sbit.111>101,011.Input:111Output:11説明:sinceallthebitsare1sowecanremovean

より良い結果を得るには、どのマウス リンカー ソフトウェアが推奨されますか? より良い結果を得るには、どのマウス リンカー ソフトウェアが推奨されますか? Jan 02, 2024 pm 07:54 PM

どのマウス ポイント コネクタが優れていますか? ポイント コネクタについては、AutoClicker を使用することをお勧めします。マウスを自動的にクリックできるようにする、シンプルで使いやすいマウス接続ソフトウェアです。その理由は、AutoClicker には次の利点があるためです。 1. インターフェースがシンプルで直感的で、操作が簡単で、初心者でも使いやすい。 2. カスタムクリック間隔時間をサポートし、必要に応じてクリック速度を調整できます。 3. さまざまなニーズに合わせて、クリック数または連続クリック数を設定できます。 4. 無料ソフトウェアなので、購入にお金を払う必要はありません。ドット コネクタを使用する場合は、AutoClicker を試してください。 Sniper 2 で Logitech マウス マクロをセットアップする方法: Sniper 2 で Logitech マウス マクロをセットアップする手順は次のとおりです: 1. まず、Logicool を購入してインストールしていることを確認します。

See all articles