zoukankan      html  css  js  c++  java
  • TC代码分析--好友,门派系统

    1、好友关系设计:

    CREATE TABLE `character_social` (
      `guid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT 'Character Global Unique Identifier',
      `friend` int(10) unsigned NOT NULL DEFAULT '0' COMMENT 'Friend Global Unique Identifier',
      `flags` tinyint(3) unsigned NOT NULL DEFAULT '0' COMMENT 'Friend Flags',
      `note` varchar(48) NOT NULL DEFAULT '' COMMENT 'Friend Note',
      PRIMARY KEY (`guid`,`friend`,`flags`),
      KEY `friend` (`friend`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Player System';

    2、门派关系设计:

    门派信息:
    CREATE TABLE `guild` (
      `guildid` int(10) unsigned NOT NULL DEFAULT '0',
      `name` varchar(24) NOT NULL DEFAULT '',
      `leaderguid` int(10) unsigned NOT NULL DEFAULT '0',
      `EmblemStyle` tinyint(3) unsigned NOT NULL DEFAULT '0',
      `EmblemColor` tinyint(3) unsigned NOT NULL DEFAULT '0',
      `BorderStyle` tinyint(3) unsigned NOT NULL DEFAULT '0',
      `BorderColor` tinyint(3) unsigned NOT NULL DEFAULT '0',
      `BackgroundColor` tinyint(3) unsigned NOT NULL DEFAULT '0',
      `info` varchar(500) NOT NULL DEFAULT '',
      `motd` varchar(128) NOT NULL DEFAULT '',
      `createdate` int(10) unsigned NOT NULL DEFAULT '0',
      `BankMoney` bigint(20) unsigned NOT NULL DEFAULT '0',
      PRIMARY KEY (`guildid`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Guild System';
    门派成员:
    CREATE TABLE `guild_member` (
      `guildid` int(10) unsigned NOT NULL COMMENT 'Guild Identificator',
      `guid` int(10) unsigned NOT NULL,    ---玩家id
      `rank` tinyint(3) unsigned NOT NULL,
      `pnote` varchar(31) NOT NULL DEFAULT '',
      `offnote` varchar(31) NOT NULL DEFAULT '',
      UNIQUE KEY `guid_key` (`guid`),
      KEY `guildid_key` (`guildid`),
      KEY `guildid_rank_key` (`guildid`,`rank`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Guild System';

    3、建立合适的sql,目的是为了增删改查,分析如下:

    1)玩家的guid来自characters,扩展好友设计时,自然使用guid作为关联,欲描述玩家A和玩家B的关系,可能有多种情况,所以加个flag,那么如何增删改查呢?

    增加好友关系:
    INSERT INTO character_social (guid, friend, flags) VALUES (?, ?, ?)
    删除:
    DELETE FROM character_social WHERE guid = ? AND friend = ?
    取玩家的好友列表:
    SELECT friend, flags, note FROM character_social JOIN characters ON characters.guid = character_social.friend WHERE character_social.guid = ? AND deleteinfos_name IS NULL LIMIT 255
    更新好友关系:
    UPDATE character_social SET flags = ? WHERE guid = ? AND friend = ?

    2)每个门派都有一个唯一id,每个门派里有若干成员,每个成员的guid唯一,所以下面这两句的用意于此吧:

    UNIQUE KEY `guid_key` (`guid`),---玩家
    KEY `guildid_key` (`guildid`),---门派id
  • 相关阅读:
    遗传算法的几种改进
    python3中让程序暂停运行的语句
    python内存增长问题
    关于编程思路
    关于程序中delay函数带来的繁琐问题
    python一切皆对象的理解
    Inspector did not run successfully.
    ProtocolError: <ProtocolError for 127.0.0.1/RPC2: 401 Unauthor.
    决策树的升入浅出-视频
    -bash: /opt/cslc/jdk1.8.0_144/bin/jps: /lib/ld-linux.so.2: bad ELF interpreter: 没有那个文件或目录
  • 原文地址:https://www.cnblogs.com/mingbujian/p/14288592.html
Copyright © 2011-2022 走看看