Nano Hash - криптовалюты, майнинг, программирование

Динамическое поле MySQL для хранения неопределенного типа данных

В настоящее время я использую MYSQL Workbench для разработки базы данных для компонента Joomla, и я столкнулся с камнем преткновения в дизайне.

Описание проблемы:

Я хочу разрешить администратору создавать поля для внешнего пользователя. Поле должно быть определено администратором с точки зрения типа и длины.

Мой дизайн:

ADMIN_FIELDS (this is the table to store admin defined fields)
id    INT
name  VARCHAR(45)
type  VARCHAR(45)

USER_FIELDS (this is the table to store user information in the fields defined by admin)
id        INT
value     LONGTEXT
admin_field_id FK_ADMIN_FIELDS  

Вопросы:

  1. Поскольку я не знаю длину поля значения, я выбрал LONGTEXT в качестве типа данных. Это может варьироваться от логического до размера LONGTEXT, в зависимости от того, что администратор выбрал в качестве типа данных. Является ли это хорошей техникой проектирования базы данных, учитывая мою проблему? Есть ли способ лучше?

  2. Будет ли снижение производительности, если я использую LONGTEXT для чего-то такого маленького, как логическое значение? В худшем случае, если админ решит сойти с ума с логическими значениями во всех полях своего сайта, и, гипотетически говоря, у него есть миллиард пользователей, которые создают эти значения. Пострадает ли тогда производительность сайта?

  3. Если нет снижения производительности, то зачем нам хранить данные в соответствующем типе данных? Почему бы не использовать LONGTEXT для всего?

Заранее спасибо за ваш ответ.

12.08.2014


Ответы:


1

Спасибо за ваши комментарии. С тех пор я провел некоторые исследования и нашел решение, адаптированное для моих нужд. В основном я разрабатываю компонент, чтобы администраторы могли создавать собственные таблицы. Таким образом, компонент будет хранить схемы таблиц, определенные администратором.

Я решил не использовать Cck или другие расширения форм, потому что хочу, чтобы этот компонент обеспечивал умную интеграцию с другими компонентами. Таким образом, компонент будет напрямую взаимодействовать с базой данных, позволяя другим компонентам легко вызывать мой компонент.

15.08.2014
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..