Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> какие таблицы создать 
:(
    Опции темы
JVM
Дата 1.2.2007, 17:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



С БД знаком очень поверхностно, поэтому такой вопрос. Посоветуйте, какие таблицы создать в БД(использую MS SQL 2005), если есть следующее:

full-name    - фамилия и имя пользователя в системе
e-mail         - электронный адрес пользователя, может быть несколько
type-rights - тип прав пользователя, под которыми он заходит в систему
host-name - имя компьютера пользователя
ip-host       - IP-адрес компьютера пользователя
password   - пароль пользователя


PM MAIL   Вверх
Rodman
Дата 1.2.2007, 17:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



-------------
TableUser
********
ID  (INCREMENT)                        
FIO  (VARCHAR)                       - можно на три поля разделить
EMail  (VARCHAR)
CodeTypeRight  (INT)
HostName  (VARCHAR)
IpHost  (VARCHAR)
Password (VARCHAR)
------------

-------------
TableTypeRight
********
ID  (INCREMENT)
Typ0eName  (VARCHAR)
-------------
PM MAIL WWW Skype GTalk YIM MSN   Вверх
JVM
Дата 1.2.2007, 18:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



а если у поьзователя несколько e-mail, то они записываются в TableUser
 под разными ID?
PM MAIL   Вверх
chief39
Дата 1.2.2007, 18:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


карманная тигра
***


Профиль
Группа: Участник Клуба
Сообщений: 1631
Регистрация: 20.5.2005
Где: Киев

Репутация: 8
Всего: 77



Цитата(JVM @  1.2.2007,  18:01 Найти цитируемый пост)
а если у поьзователя несколько e-mail, то они записываются в TableUser
 под разными ID? 

А вот тут вопрос требований, а не структуры
Если нужен ОДИН мэйл, неизменный, допустим для человека - тогда просто себе поле

Если их много - тогда дополнительная табличка - <мэйл>,<ID человека>


--------------------
Люди - это свечи. Они либо горят, либо их - в жопу!(с)

PM MAIL   Вверх
JVM
Дата 2.2.2007, 09:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



Возникли еще вопросы. Как хранить IP-адрес? Могут ли мне понадобиться отдельные части IP?
Использую Java. Стоит ли смотреть в сторону hibernate?

Это сообщение отредактировал(а) JVM - 2.2.2007, 09:08
PM MAIL   Вверх
Rodman
Дата 2.2.2007, 09:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



JVM, если у юзера могут быть несколько почтовых ящиков - то

-------------
TableUser
********
ID  (INCREMENT)                        
FIO  (VARCHAR)                       - можно на три поля разделить
CodeEMail  (VARCHAR)
CodeTypeRight  (INT)
HostName  (VARCHAR)
IpHost  (VARCHAR)
Password (VARCHAR)
------------

-------------
TableTypeRight
********
ID  (INCREMENT)
TypeName  (VARCHAR)
------------- 


-------------
TableEmail
********
ID   (INCREMENT)
IDUser   (INT)
EmailName  (VARCHAR)
------------- 

а про IP - лучше хранить его целиком...
PM MAIL WWW Skype GTalk YIM MSN   Вверх
JVM
Дата 2.2.2007, 10:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



Rodman, но если так делать, то в TableUser получается избыточность.
Зачем в TableEmail создавать поле ID? Ведь сам по себе EmailName уже уникален.
PM MAIL   Вверх
Rodman
Дата 2.2.2007, 10:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



Цитата(JVM @  2.2.2007,  09:14 Найти цитируемый пост)
Зачем в TableEmail создавать поле ID?

Я всегда при создании новой таблицы создаю ей ID - потому что при возможном (дальнейшем) расширении базы, может понадобится использования ID этой таблицы... (согласен, если тебе не надо, мож не добавлять это поле)...

Решай сам... мож мой метод глупый, но ИМХО я так делаю, т.к. мои базы состоят как минимум из 20 таблиц...
PM MAIL WWW Skype GTalk YIM MSN   Вверх
LSD
Дата 2.2.2007, 11:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Цитата(JVM @  2.2.2007,  09:08 Найти цитируемый пост)
Могут ли мне понадобиться отдельные части IP?

Это мы должны знать? smile 


Цитата(JVM @  2.2.2007,  10:14 Найти цитируемый пост)
Зачем в TableEmail создавать поле ID? Ведь сам по себе EmailName уже уникален.

Поищи по форуму, тема "естественные ключи vs синтетические" уже обсуждалась.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
SergeBS
Дата 2.2.2007, 14:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1111
Регистрация: 10.6.2005
Где: Владимир

Репутация: 1
Всего: 22



Rodman
Цитата
FIO  (VARCHAR)                       - можно на три поля разделить

Не можно, а НУЖНО.

JVM
На DelphiKingdom - статья Т.Тенцера "Естественные ключи против искусственных". Читай.
Я давно сделал практический вывод для себя: в любой таблице - столбик типа autoinc иметь в обязательном порядке, даже если в ней никогда не будет больше 10 записей. Поскольку обычно "никогда" не бывает. Год-два - и вдруг нате.
PM MAIL   Вверх
Rodman
Дата 2.2.2007, 14:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



SergeBS, не я же базу делаю, я просто советую...

Я с тобой полностью согласен - писал выше 
PM MAIL WWW Skype GTalk YIM MSN   Вверх
JVM
Дата 2.2.2007, 15:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



Спасибо. Перевариваю.
Вот статья http://vingrad.ru/DELPHI-DLP-002700
PM MAIL   Вверх
skyboy
Дата 2.2.2007, 16:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 5
Всего: 260



Цитата(JVM @  2.2.2007,  09:14 Найти цитируемый пост)
Зачем в TableEmail создавать поле ID? Ведь сам по себе EmailName уже уникален. 

дело  здесь, в первую очередь, не столько в "естественности", сколько в длине: при работе с самим адресом имеешь ключ переменной длины(что само по себе сильно влияет на скорость работы) и длиной - не менее 6 байт(ну, вроде "[email protected]"), в то время, как unsigned long int, если память мне не изменяет, фиксировано 8 байт. И не больше. 
PM MAIL   Вверх
JVM
Дата 7.2.2007, 18:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 189
Регистрация: 30.10.2006

Репутация: нет
Всего: 5



Rodman, елси у пользователя будет несколько email, то зачем TableUser создавать столбец CodeEMail  (VARCHAR)?

TableUser
********
...
CodeEMail  (VARCHAR)
...

PM MAIL   Вверх
Rodman
Дата 13.2.2007, 16:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



создай отдельную таблицу для Email
PM MAIL WWW Skype GTalk YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1379 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.