Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Как получить имена столбцов таблице? [2]

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (2): « 1 [2]   

> Без описания
DeepVarvar Супермодератор
Отправлено: 13 Ноября, 2011 - 01:04:55
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




DeMonyan пишет:
Ваш запрос не даст информацию о том откуда считать возможные данные для ввода в столбец.
Вы шутите?
Даже не попробовали чтоли?
PHP:
скопировать код в буфер обмена
  1. $result = mysql_query("SHOW FIELDS FROM tbl");
  2. $arr = array();
  3. while ($row = mysql_fetch_assoc($result)) $arr[] = $row;
  4. var_dump($arr);

С ассоциативным массивом справитесь?

(Отредактировано автором: 13 Ноября, 2011 - 01:09:14)

 
 Top
DeMonyan
Отправлено: 13 Ноября, 2011 - 15:00:20
Post Id



Новичок


Покинул форум
Сообщений всего: 43
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




С массивом справлюсь, но тем не менее нужных данных этот запрос НЕ ДАЁТ!

[2]=> array(6) { ["Field"]=> string(6) "Region" ["Type"]=> string(7) "int(11)" ["Null"]=> string(3) "YES" ["Key"]=> string(3) "MUL" ["Default"]=> NULL ["Extra"]=> string(0) "" }

Это по столбцу мало! Толку мне знать что это ключ и что это числовое поле?! Мне нужно знать какое поле и из какой таблицы используется для связи.
 
 Top
DeMonyan
Отправлено: 13 Ноября, 2011 - 17:35:09
Post Id



Новичок


Покинул форум
Сообщений всего: 43
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




В идеале лучше вообще получить Referenced table и Referenced field... Но я сколько не ищу не могу найти каким запросом можно получить эти данные. ((
 
 Top
DeMonyan
Отправлено: 14 Ноября, 2011 - 10:01:16
Post Id



Новичок


Покинул форум
Сообщений всего: 43
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




Всем спасибо, вопрос решил - SHOW CREATE TABLE и функции работы со строкой.
 
 Top
DeMonyan
Отправлено: 15 Ноября, 2011 - 16:05:30
Post Id



Новичок


Покинул форум
Сообщений всего: 43
Дата рег-ции: Нояб. 2011  


Помог: 0 раз(а)




Вдруг кому пригодится:

PHP:
скопировать код в буфер обмена
  1. function get_foreign_field($tbl)
  2. {
  3.     $query="show create table ".$tbl;
  4.     $result=ExecuteQuery($query);
  5.     $row=mysql_fetch_array($result);
  6.     $str=$row[1];
  7.     while ($str!="") {
  8.         $str1=strstr($str,"FOREIGN KEY");
  9.         for ($i=0;$i<3;$i++) {
  10.             $f[$i]=substr(substr($str1,strpos($str1,"`")+1),0,strpos(substr($str1,strpos($str1,"`")+1),"`"));
  11.             $str1=substr(substr($str1,strpos($str1,"`")+1),strpos(substr($str1,strpos($str1,"`")+1),"`")+1);
  12.         };
  13.         $forkeys[]=$f;
  14.         $str=strstr($str,"FOREIGN KEY");
  15.         $str=substr($str,11);
  16.     };
  17.     return ($forkeys);
  18. };
  19.  


Вот такая функция выдаёт в двумерный массив все ключи. По первому индексу перебираются ключи, по второму данные в них:
0 - поле из данной таблицы имеющее зависимость.
1 - имя таблицы с которой связано поле.
2 - имя столбца в связанной таблице.

Строковые преобразования явно можно проще сделать, но сейчас переделывать пока нет желания.
 
 Top
Страниц (2): « 1 [2]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB