![]()  | 
	
 
  | 
		
			
  | 	
	
	
		
		|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны | 
![]()  | 
	
	
| 
		 | 
	Опции темы | Поиск в этой теме | Опции просмотра | 
| 
		 
			 
			#1  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Здравствуйте! 
		
	
		
		
		
		
		
	
		
		
	
	
	Как создать по скрипту DDL визуальное представление модели данных, то есть получить что то вроде er - диаграммы. Help...  | 
| 
		 
			 
			#2  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 На ум приходит только одно: 
		
	
		
		
		
		
			
		
		
		
		
	
		
		
	
	
	Парсить текст скрипта и в зависимости от него рисовать диаграмму. Алгоритм типа такого : -Убираем все пробелы вначале текста -Определяем первое слово -Например оно create, значит рисуем прямоугольник и всего вписываем то что после table\view -ищим следующие слово,т.е. имя поля, и дорисовываем к прямоугольнику снизу два отрезка по побокам, т.е. продолжаем прямоугольник в низ - повторяем пока не встретим ');', когда нашли рисуем последнюю черту, закрываем прямоуголник. ну что-то такое ![]()  | 
| 
		 
			 
			#3  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Спасибо за алгоритм. 
		
	
		
		
		
		
		
	
		
		
	
	
	Но у меня сложность как нарисовать этот прямоугольник и написать в нем текст в отдельных полях, т.е сделать вид как у таблицы Помогите...  | 
| 
		 
			 
			#4  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Canvas.Rectangle() и Canvas.TextOut() тебе помогут. 
		
	
		
		
		
		
		
	
		
		
	
	
	А вообще, можно просто в некоторой внутренней базенке просто создавать нужные объекты просто прогоняя скрипт и потом из этой базенки все читать. хотя create table довольно стандартная вещь и ее можно распарсить. А вот create view можно написать разными способами и без "крутого" анализа там фиг разберешься.  | 
| 
		 
			 
			#5  
			
			
			
			
		 
		
		
	 | 
|||
		
		
  | 
|||
| 
	
	
		
			
			 Я с такой задачей столкнулся впервые. 
		
	
		
		
		
		
		
	
		
		
	
	
	Не поможете мне разобраться с этим, как это будет в коде. Заранее спасибо  | 
| 
		 
			 
			#6  
			
			
			
			
		 
		
		
	 | 
||||
		
		
  | 
||||
| 
	
	
		
			
			 В общем самому стало интересно и решил что-то накалябать  
		
	
		
		
			в итоге: 1) мой способ про парсинг запроса - хрень 2) способ lmikle работает, но тут надо учитывать диалект базы, т.е. для кого-то есть тип char а кому-то и varchar тут. накалябал пример на основе аксеса (mdb). Для получения полей тупо делал селект и потом разбирал полученный датасет... в идеале было бы лучше сделать запрос к системным таблицам что бы получить структуру (в нормл базах такое есть), для аксеса я такого не знаю. p.s. хочу плюс ![]()  |