RSS

Компьютерная терминология    1_9  A  B  C  D  E  F  G  H  I  J  K  L  M  N  O  P  Q  R  S  T  U  V  W  X  Y  Z  .....  A  Б  В  Г  Д  Ж  З  И  К  Л  М  Н  О  П  Р  С  Т  У  Ф  Х  Ц  Ч

PHP

 
PHP умеет работать в 3х режимах:

1. Как модуль apache (mod_php), тогда php выполняется от того же пользователя, от которого запущен apache.

2. В режиме FastCGI (по скорости php-fcgi и не медленнее mod_php).

3. В режиме просто CGI (медленее чем mod_php).

Suexec может использоваться как для 3 варианта, так и для 2, и в случае 2, то есть php запускается как fastcgi, плюс suexec, Вы получите систему, в которой каждый отдельный сайт можно будет запускать от имени и с правами разных аккаунтов, но работать все будет под одним и тем же apache. Так и устроены многие shared-хостинги.

Функции в РНР.

Что нужно понимать под функцией в программировании? Функция – последовательность инструкций, имеющая имя и результат. Т.е. вы один раз оформляете, какой то кусок кода, как функцию, а потом, можете использовать его, вызывая функцию, в любом месте вашей программы. PHP обладает большим количеством встроенных функций. Но, очень часто бывает нужно, использовать собственные функции. Например, в разных частях программы, нужно выполнять, какие то похожие действия. Не переписывать же каждый раз один и тот же фрагмент кода.

Работа со строками в РНР.

Новости

Здесь вы сможете узнать как сделать фон в html, все описано просто и доступно.
 
Конкатенация строк. Этим хитрым словом называется присоединение одной строки к другой. Начиная с PHP 3-ей версии, для сложения строк применяется оператор «.». (раньше использовался +). Существует ещё один способ сложения строк. В виду того, что каждая переменная начинается со знака $, то если написать echo “Привет $name”; вместо $name будет подставлено значение переменной $nam.

Работа с файлами в РНР

Продолжим рассматривать особенности работы с файлами в РНР. В этой части я расскажу о полезных функциях, для работы с файлами, которые не вошли в первую статью (временные файлы, чтение файлов CSV, функции для работы с именами файлов, блокировка файлов). Итак, обо всём по порядку. Иногда необходимо организовать в программе работу с временными файлами. Функция int tmpfile() создаёт новый файл с уникальным именем и открывает его на чтение/запись. Чтение CSV файлов. Знаете что такое CSV файлы? Если нет, вспомните программу Microsoft Exel. CSV - это один из форматов, в которых Exel может сохранять свои таблицы.

Голосование на PHP

Голосование - хорошее средство для того, что бы узнать мнение посетителей сайта, по какому либо вопросу. Хорошо продуманное голосование может помочь понять веб мастеру, что не так на его сайте, что нужно изменить, что добавить и т.д. Но, не буду Вас учить, как выбирать тему для голосования. Лучше подскажу, как написать удобную систему голосований. Переходим к делу. Несколько слов, о том, каким будет скрипт, и как он должен работать. С помощью скрипта можно будет создавать неограниченное количество голосований. Скрипт будет называться vote.php, а файл, в котором хранится инфа по голосованиям - vote.dat. Скрипт состоит из админской части, части, которая отображает голосование, и которая учитывает голоса. Чтобы получить доступ к любой из этих частей, будем использовать параметр-переменную action.

Mail форма

Mail-формы представляют собой html форму связанную с web скриптом. Их цель отправлять письма на указанный адрес email. При этом, отправителю не нужно запускать почтовую программу, он может вообще не иметь почтового ящика. Вы согласны, что будет не плохо, если посетитель, не отрываясь от просмотра вашего сайта, сможет отправить вам пожелание, замечание, благодарность и т.д.? Если да, тогда начнём писать наш скрипт. И html форма и скрипт будут находится в одном файле. Назовём его mail.php. В форме будет три поля: имя отправителя, его email, текст сообщения.

Работа с формами

Данная статья расскажет Вам, как осуществить связь между пользователем и PHP скриптом.В большинстве скриптов, пользователь должен передать им какие-либо параметры. Пример – гостевая книга. В качестве параметров этому скрипту обычно передаются текст сообщения, имя и email посетителя.

Счётчик на PHP

Советую использовать этот пример только в учебных целях, так как он имеет большое количество недостатков, которые будут рассмотрены далее. Итак, начнем. Каждый раз, когда посетитель заходит на страницу с данным кодом, скрипт выдаёт ему число - количество посетителей. Это число должно где-то храниться. Используем для этого файл. Для того, что бы работать с файлом, его нужно открыть.

Работа с файлами в PHP.

Использования файлов в любом языке программирования открывает для программиста абсолютно новые возможности. Теперь можно сохранять данные на диск, и использовать их в любой момент. Работать с файлами в PHP очень просто (как впрочем, и со всем остальным). Всю работу с файлом можно разделить на три этапа. 1)Открытие файла. При открытии файла возвращается число – дескриптор файла. При этом вся дальнейшая работа ведётся именно с этим дескриптором. 2)Выполняется обработка файла (запись, чтение и т.д.) 3) Закрытие файла.

Основные конструкции языка PHP.

В этой статье я расскажу о языковых конструкциях языка веб программирования PHP. Изучив их, вы уже сможете писать простенькие программы. Особенностью конструкций этого языка является простота. if-else, while, for, foreach, case - основные конструкции языка. Рассмотрим каждую из них подробнее.

Переменные в PHP

Вы никогда не хотели сделать свой сайт интерактивным, гибким, динамическим? Не задумывались ли Вы, как создають гостевую книгу, форум, голосование, чат и т.д.? Всего этого можно легко добиться с помощью языков веб программирования. Среди этих языков особенно известны Perl и PHP. У каждого из них есть свои преимущества и недостатки. Но я посоветовал бы начать изучать именно PHP. Основным его плюсом является простота изучения. Тем не менее, эта простота не мешает ему сочетать в себе все достоинства Perl. На РНР можно написать практически всё: начиная от простого счётчика посещений и заканчивая поисковой системой (напр. движок сайта aport.ru написан на PHP). Число сайтов использующих PHP растёт с огромной скоростью. Аргументов, для того, чтобы ознакомится с РНР, по-моему, достаточно.

Что такое PHP?

PHP (его полное название: PHP: Hypertext Preprocessor) - это язык, предназначенный для быстрого создания динамических web-страниц.

Синтаксис языка похож на С, Java и Perl, однако имеет и свои, присущие только ему особенности. В официальной документации PHP определяется как server-side HTML-embedded scripting language (встраиваемый в HTML скриптовый язык с обработкой на сервере).

Из этого определения можно выделить два основных момента:

  1. Обработка кода PHP производится на сервере, а не в браузере клиента, как, например JavaScript

  2. Код PHP может быть встроен непосредственно в тело HTML страницы, что выгодно отличает его от Perl.

Ниже приведен пример PHP скрипта, взятый из фирменной документации по PHP, код PHP выделен синим цветом.

<html>
  <head>
     <title>Example</title>  
<?php echo "Hi, I'm a PHP script!"; ?>

Из этого примера виден принцип встраивания кода PHP в HTML код страницы: все, что находится между начальным и конечным тегом PHP (<?php и ?> соответственно) считается PHP кодом и обрабатывается интерпретатором PHP.

Немного истории

Создателем PHP первоначально был Rasmus Lerdorf, но сейчас разработкой этого языка занимается довольно большое количество людей, поставивших своей задачей его дальнейшее расширение и развитие. За время своего существования (а первая версия PHP появилась в конце 1994 года) этот язык претерпел очень значительные изменения, коснувшиеся как внешней его структуры (синтаксиса, набора функций и т.п.), так и внутренней организации. Последний раз подобные глобальные изменения коснулись PHP с появлением 4-й версии этого языка, когда PHP был полностью переписан с использованием Zend scripting engine, разработанным компанией Zend technologies. Это позволило добавить в синтаксис языка ряд новых функций, а также сделать его существенно быстрее, чем предыдущие версии. Причиной, по которой удалось добиться таких результатов является то, что Zend scripting engine является наполовину компилятором, т.е. компилирует PHP код, а уж затем производит его выполнение, тогда как предыдущие версии PHP были по своей сути интерпретаторами. В наших публикациях мы в основном будем вести разговор именно о PHP версии 4. Кстати, на момент публикации этой статьи последняя официальная версия PHP имеет номер 4.0.6

Синтаксис PHP

Как уже было сказано ранее - синтаксис PHP во многом заимствован из таких языков как C, Java и Perl. Поэтому, если вы знакомы хотя бы с одним из них - вам не составит особого труда просто сесть и начать писать программы на PHP. Здесь мы не будем подробно останавливаться на описании синтаксиса - он хорошо описан в PHP Manual. Однако мне хотелось бы остановиться на некоторых аспектах, которые отличают PHP от других языков.

Имена переменных

Любая переменная в PHP имеет имя, начинающееся со знака $, например $variable. Людям, привыкших к C/C++-подобным языкам этот принцип именования переменных может показаться странным, но на самом деле такой подход имеет определенные преимущества.

  1. При таком способе формирования имен переменных их очень легко отличить от остального кода. Если в других языках иногда может возникать путаница с тем, что при первом взгляде на код не всегда ясно - где здесь переменные, а где функции, то в PHP этот вопрос даже не встает.

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

  $name = 'value';
  $value = 5;
  echo $$name;

В данном примере PHP выведет результат 5. Такие фокусы стали возможны из-за заложенного в PHP принципа: "anything is an expression" (любая вещь является выражением). Исходя из этого PHP воспринимает выражение $$name следующим образом:

Как видите, это очень гибкая система и при небольшой тренировке вы сможете просто творить чудеса с ее помощью! Ведь точно так же можно оперировать с любыми элементами языка, имеющими имя, т.е. например вызывать метод класса по его имени, содержащемуся в переменной (о классах в PHP мы поговорим в одной из следующих публикаций).

Строки

Возможность однозначно идентифицировать переменную позволила создателям PHP дать возможность программистам использовать переменные непосредственно внутри строк! Пример подобного использования:

  $name = 'John';
  $age = 23;
  echo "$name is $age years old";

В качестве результата мы получим строку: John is 23 years old.

Не правда ли, это исключительно удобно? Однако необходимо обратить ваше внимание на одну деталь - в PHP, в отличие от многих других языков, различаются строки, заключенные в одинарные и двойные кавычки. И подобное замещение имен переменных их значениями производится только в строках, заключенных в двойные кавычки! Очень важно всегда помнить об этом, дабы избежать ошибок.

Строки, заключенные в двойные кавычки могут содержать и более сложные выражения. Для этого необходимо заключить их в фигурные скобки:

  $man = array('John',23);
  echo "{$man[0]} is {$man[1]} years old";

Результат будет таким же, как и в предыдущем примере.

Еще одной интересной особенностью работы PHP со строками является поддержка т.н. here docs. Ниже приведен пример:

  $str = <<<TEXT
 There can be any text
  which will be stored
      into a string
    right in the same way
      as it
  typed here
TEXT;

В этом случае значением переменной будет весь текст, содержащийся между начальным и конечным маркерами (в данном случае это строка TEXT, но этот маркер может быть любой последовательностью символов). Признаком того, что это here doc, является наличие <<< непосредственно после знака присваивания. Данный механизм очень удобен в случае, если строке необходимо присвоить какой-то сложный текст, особенно, если необходимо сохранить его форматирование. Кстати, в случае использования here docs вы также имеете возможность использования переменных внутри строки как это было описано ранее.

Массивы

Массивы в PHP - это очень мощный и гибкий механизм. Он позволит вам сделать практически все, что вы только можете пожелать сделать с массивами. Поддерживаются как обычные, так и ассоциативные массивы, причем они могут быть смешаны в любом порядке даже в пределах одного массива. Поддерживаются вложенные массивы, их вложенность никак явно не ограничена. В PHP существует большое количество функций для работы с массивами, они помогут вам выполнить большинство

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

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

$data = array(1,10,100,1000,                // Численные данные
              'Some text','Another text',   // Строковые данные
              'name'=>'John','age'=>23,     // Ассоциативные связи в массиве
              'date'=>array('day'=>10,'month'=>'may','year'=>2001)); 
//Вложенный массив

Как видите - различные данные могут быть совмещены вместе в единой структуре без каких-либо проблем! Посмотрим, как можно обратиться к этим данным:

  echo $data[1];               // Результат - 10
  echo $data[5];               // Результат - 'Another text'
  echo $data['age'];           // Результат - 23
  echo $data['date']['month']; // Результат - 'may'

Большое количество информации и примеров, а также описания функций для обработки массивов можно найти в PHP Manual

Variable scope

Английский термин, вынесенный в заголовок переводится на русский как "область видимости переменной", но в оригинале этот термин намного понятнее.

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

В PHP на этот счет есть свои особенности. Самая "странная" вещь, с которой сталкивается человек при знакомстве с PHP это то, что переменная, описанная вне функции невидима внутри нее! В других языках программирования мы привыкли к тому, что глобальные переменные программы видны везде, но в PHP это не так. Но посмотрев на эту "странность" повнимательнее можно заметить, что она имеет больше выгоды, нежели неудобств, т.к. является своего рода "защитным механизмом", который не позволит вам случайно перепутать локальную и глобальную переменную, что подчас приводит к очень тяжелым последствиям.

Как же получить доступ к глобальным переменным из функции? Есть 2 способа сделать это:

  1. Использовать глобальный ассоциативный массив $GLOBALS. Это единственная переменная в PHP, которая видна отовсюду и которая "содержит" в себе все глобальные переменные, имеющиеся в программе. Т.о. если вы внутри функции обращаетесь к переменной $variable - то вы обращаетесь к локальной переменной, а если $GLOBALS['variable'] - то к глобальной.

  function myFunction() {
    $variable = 5;               // Присваиваем значение локальной переменной
    $GLOBALS['variable'] = 10;   // Присваиваем значение глобальной переменной
  };
  1. Использовать ключевое слово global. Оно позволит вам задать список глобальных переменных, которые будут видимы внутри функции:

  function myFunction()  {
      global $variable;
      $variable = 10;       // Присваиваем значение глобальной переменной
  };

Комфортная работа с PHP

При написании кода на php возникает одна маленькая проблема, которая грозит поглотить существенное время от отведенного на разработку. Эта проблема стара как мир - отладка написанного кода. И для решения этой проблемы хочется держать на машине минимальный по объему и достаточный по функциональности пакет программ, комфортных в работе и не требовательных к финансовому благополучию клиента.

После поисков при столь суровых требованиях автор остановил свое внимание на следующем программном продукте - PHPEdit.

Для того чтобы разрабатывать и тестировать(с помощью средств отладки, а не только посредством вывода тестовых сообщений в коде) написанные на php скрипты, хочется рекомендовать использовать следующий набор:

Еще одна вещь, облегчающая общую работу - "Денвер". Он объединяет в себе множество необходимых решений (веб-сервер Apache, php, mysql) позволяя резко сократить время настройки домашнего рабочего комплекта, не теряя при этом в качестве работы. Итоговый объем установленного PHPEdit (включая файлы помощи и DBG) суммарно занимает на диске 15 мб.

Рассмотрим по порядку обустройство рабочего места.

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

Обеспечив место для экспериментов, обратимся ко второму шагу. Он включает в себя установку редактора PHPEdit. Установка сведена к минимуму. В выбранный вами каталог копируем ZIP-архив с редактором и распаковываем архив. Все. У нас на руках полностью готовый к работе PHPEdit.

Для того чтобы приступать непосредственно к процессу написания и отладки скриптов, осталось сделать последние шаги: установить документацию на PHPEdit и непосредственно сам отладчик. Документация - устанавливается как и PHPEdit - распаковкой ZIP-архива в выбранный вами каталог. Отладчик забираем у создателя, после чего открываем в документации очень важный документ (module.DBG.html) и следуем буквально по шагам согласно его рекомендаций.

Все. По завершению этих манипуляций у нас обустроенное место, состоящее из "Денвер", PHPEdit и отладчика DBG, которые совместно составляют полнофункциональную систему, способную решить проблемы выполнения процесса отладки php-кода.

Теперь давайте рассмотрим непосредственно сам редактор, в котором мы и будем проводить львиную долю времени.

Текущая версия включает в себя:

PHPEdit поддерживает следующий набор форматов обрабатываемых файлов (с поддержкой синтаксиса для каждого): CSS, HTML, PHP, INI, JavaScript, обычный текст, XML. Использовать описанные форматы - личное дело каждого, но большую часть возможностей использовали все же в варианте php-редактора.

Одной из важных особенностей PHPEdit является то, что фактически любые действия в нем прописаны в виде самостоятельных команд, доступ к которым возможен через окна настройки. Поэтому стандартные возможности редактора и клавиши управления можно переопределить и перенастроить под свои нужды и привычки.

Например, по умолчанию PHPEdit поддерживает уже интегрированный парсер кода, который производит подстановку кавычек, скобок, завершает начатые конструкции php и старается облегчить жизнь программисту. К сожалению, некоторые из его навязчивых действий не всегда удобны и для желающих настроить среду обитания под себя можем порекомендовать отключить помощника (aoPHPAutoComplete в Help - About - General Option Dialog) и закодировать ненужные комбинации через механизм шаблонов и вызова команд.

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

Полученный код можно экспортировать для последующей публикации в html формат, либо в RTF. К сожалению, при экспорте автоматически не подставляется стандартное расширение для создаваемых файлов (это надо помнить, когда будете работать с сгенерированными файлами) и в RTF "раскраска" кода оставляет желать лучшего, а также существенно отличается от выбранной в редакторе. Html-вариант экспорта нареканий не вызывает.

Возможности редактирования и поиска - стандартны. Выделение, взятие в буфер, удаление текста, возврат по списку произведенных изменений. Поиск и замена организована с поддержкой различных направлений поиска. Мощной возможностью является поддержка регулярных выражений в поиске и замене.

Блок Tools объединяет в себе все возможные настройки редактора. Сюда входят:

Блок View содержит возможность настройки инструментов (toolbars), быстрого переключения между видами подсветки синтаксиса, окна отладчика (точки остановки, окно вывода, значения переменных с их делением на глобальные, локальные), окно быстрой навигации по коду.

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

При работе с PHPEdit нужно помнить, что в случае его запуска автоматически также запускается отладчик DBG, который перехватывает все обращения к заранее описанному в конфигурации потру и осуществляет обработку всех обращений к php-коду. Фактически при работе в связке "Денвер" - PHPEdit - DBG составные части сливаются в одно целое и через какое-то время воспринимаются как одно целое.

Хочется отметить одну забавную особенность в интерфейсе PHPEdit. Визуально не различаются диалоговые окна настроек, часть из которых может динамически менять размер, а часть не может. Изучается данная возможность только методом тыка. Достаточно удобно работать с окнами, где это поддерживается, но остается вопрос, почему подобное поведение распространяется не на все вызываемые окна в программе.

Напоследок хочется дать рекомендацию для любителей использовать клавиатуру. Чтобы ускорить работу с закладками, лучше всего удалить уже описанные горячие клавиши (раздел Tools - Edit Syntax Properties - Key Assignments - Bookmarks). Вместо этого завести отдельные "горячие клавиши" (Tools - Edit Shortcuts), более удобные для вас лично. Опыт показывает, что это сделать проще, чем попытаться заставить стандартный обработчик закладок понимать комбинации клавиш с использованием Ctrl или Alt. К счастью, "горячие клавиши" работают с любыми вариантами задаваемых комбинаций, что решает названную проблему.

Необходимо отметить очень важную вещь - PHPEdit является динамично разрабатываемым продуктом, в котором активно участвует его коммуннити. Это выливается в поддержку продукта, апдейты, быструю реакцию на добавление новых возможностей и внесенение необходимых изменений. Кроме того, доступны люди, осуществляющие техническую поддержку. Минус для русскоговорящих - поддержка понимает английский язык и не общается на русском. Но решаются вопросы очень быстро, в чем у автора была возможность убедиться лично.

PHP и MySQL

O MySQL и взаимодействии её с РНР. Для начала о том, что из себя представляет MySQL. Это одна из самых распространённых систем управления реляционными базами данных (СУБД), работающая на базе языка SQL. Большую известность эта СУБД получила благодаря своей надёжности, быстроте, и тому, что распространяется она бесплатно.

Небольшой рассказ о том, что такое база данных. Реляционная база данных это совокупность связанной информации, сохраняемой в виде двухмерных таблиц (записная книга, таблица Excel).

Например:

Имя          |    телефон    

----------------------------------------

Вася         |       22-12-334

Петя         |       333-23-22 

Коля         |       03

Название реляционной она получила потому, что в 1970 г. Э.Кодд предложил использовать для обработки данных теорию множеств и доказал, что данные можно представить в виде таблицы, которая на математическом языке называется «отношением» (по-английски relation).

Для чего нужны базы данных? Понятно, что для хранения информации, но ведь хранить её можно и в файлах. Однако хранение в базе даёт неоспоримые преимущества.

1)Высокая скорость доступа к информации.

2)Возможность быстро добавлять, удалять, сортировать, искать данные.

3)В отличие от файлов, отсутствие проблем совместного доступа к информации.

Прежде чем начать работу с базой данных с ней нужно соединиться. int mysql_connect([string $hostname] [,string $username] [,string $password]) – С помощью этой функции РНР мы соединяемся с базой данных MySQL расположенной на хосте $hostname(обычно localhost). Вместо $username, $password нужно указать логин и пароль на доступ к БД. Функция возвращает идентификатор установленного соединения. Это может пригодиться, если Вы будете работать с несколькими соединениями с базой одновременно. По завершении работы с MySQL сервером нужно закрыть с ним соединение mysql_close().

Для того чтобы начать работу c базой и посылать ей SQL запросы недостаточно просто соединиться с сервером. Необходимо выбрать базу данных, с которой Вы собираетесь работать. Делает это функция

int mysql_select_db(string $dbname [,int $link_identifier]) – где $dbname – имя базы, с которой нужно работать. Необязательный параметр $link_identifier – указывает, что база данных $dbname будет использоваться для работы именно с соединением $link_identifier. Если он не указан, то используется последнее установленное соединение.

Для отправки запросов базе служит функция resource mysql_query(string $query [, $link_identifier]). Результатом функции является идентификатор ответа СУБД. Дело в том, что, когда мы посылаем запрос базе, она их обрабатывает и сохраняет результат обработки на сервере. Затем, уже по отдельному запросу результат возвращается к нам обратно. Это сделано для того, чтобы ускорить соединение с базой. Ведь в большинстве случаев, нам будет нужен не весь результат запроса, а только некоторая его часть. Вернёмся к рассмотрению функции. $query - строка-запрос, составленная по правилам языка SQL. $link_identifier – имя используемого соединения. Результат, который возвращает функция mysql_query() – служит параметром для многих других функций для работы с БД (об этом ниже).

Для того чтобы создать таблицу нужно воспользоваться следующим SQL запросом: create table имя_таблицы(имя_поля1, тип_поля1,…, имя_поляN, тип_поляN).

В MySQL существует 6 основных типов полей: целочисленные, нецелочисленные, двоичные , дата и время, строковые, текстовые.

В свою очередь целочисленные типы подразделяются на:

int (длина) [unsigned] – целые числа 4 байта. Если указан параметр unsigned, то в поле можно будет хранить только беззнаковые числа (т.е. числа > = 0).

bigint, smallint, mediumint, tinyint – все эти типы отличаются от предыдущего только максимальным размером числа, которое может в них храниться. (8, 2, 3, 1 байт соответственно).

Нецелочисленные типы.Имя типа [(максимальная длина, количество цифр отведенных для дробной части числа)] [unsigned]; Имена типов могут быть: float – число одинарной точности. double(или real) – число двойной точности, decimal – дробное число, хранящееся в виде строки. Поля типа Date, Time или Timestamp – хранят время и дату. Разница в форматах хранения.

Логические типы:Blob – двоичный объект длиной до 65535, longblob(2^32), mediumblob(16777215), tinyblob(255);

Cтроки:Тип Сhar(длина) – строка фиксированной длины. Длина может быть от 1-го до 255 символов. При этом, если ваша строка меньше указанной длины, то это не повлияет на количество памяти, выделенное под этот тип.

Varchar(длина) – может хранить от 1-го до 255 символов, но в отличии от предыдущего, выделяется столько памяти, сколько действительно содержит строка.

Текстовые типы. Поле типа Text – может содержать в себе не более 65 535 символов. Существуют также tinytext, mediumtext и long text.

Q: Как на PHP написать скрипт, определяющий MAC-адрес человека, пытающего зайти на конкретную страницу? Хочется написать систему фильтров, с помощью которой в дальнейшем реализовать так называемый черный список. Скрипт стоит на локальной машине с WinXP и Apache.

A: В случае, когда скрипт стоит на локальной машине и имеется возможность изучить текущее состояние ARP-кэша системы, затребованная задача вполне выполнима. Достаточно получить отчет системы о состоянии ARP-таблицы (($macadd=exec("arp -a")). После чего с помощью банального поиска, организованного стандартными процедурами и функциями PHP, найти в отчете MAC-адрес, который будет соответствовать предварительно определенному IP-шнику посетителя.

Q: Pазрабатываю сайт для одной конторы, торгующей программным обеспечением. Компания хранит все свои прайс-листы в формате Excel, а они создаются какими-то бухгалтерскими программами. Мне предлагают настроить автоматическую закачку этого xls-файла на сервер, но я хочу пойти дальше и отображать обновленный прайс прямо на самой веб-странице. Отсюда вопрос: каким образом можно средствами PHP динамически обработать лист Excel’а и преобразовать его в HTML-вид?

A: Здесь тебе не обойтись без библиотеки PHP-ExcelReader. Вкратце объясню, как ее использовать:

1. Для начала подключим файл с описанием класса командой include('reader.php').

2. Далее создаем экземпляр класса: $xl_reader = new Spreadsheet_Excel_Reader().

3. Указываем объекту, какой именно файл (filename.xls) необходимо обработать: $xl_reader->read("filename.xls"). После этого вся извлеченная информация будет помещена в хранилище данного объекта.

4. Контейнерами для хранения данных служат обычные двумерные массивы. Поэтому для доступа к ним не надо применять какие-либо специфические и изощренные методы и функции. Просто работай с массивом, как ты это делаешь по десять раз на дню.

5. Общий синтаксис команды выглядит следующим образом: $xl_reader->sheets[x][y], где x - это номер листа в документе, а y - одно из специальных свойств.

6. Например, чтобы присвоить переменной $rows количество строк на первом листе (нумерация листов начинается с нуля!), достаточно использовать команду $rows = $xl_reader->sheets[0]['numRows'].

7. Команда для извлечения информации из первой ячейки второго листа:

$cell = $xl_reader->sheets[1]['cells'][1][1].

8. А следующая команда может быть полезна, если необходимо возвратить имя листа:

$sheetname = $xl_reader->boundsheets[0]['name'].

seo & website usability   inet   os faq   hardware faq   memory   video   cpu   hdd   mainboard faq   printer & scaner   modem   mobiles   hackzone

Технологии поискового маркетинга
Практика поискового маркетинга
Flash
Тэги
XML
DHTML
PHP
MySQL
WebMail
.NET
VBScript
CGI
Графические форматы Интернета
WEB-сайт шаг за шагом
CMS faq
FRAME faq
CSS faq
SSI faq
RSS faq
WAP faq
Web-Designed
Webhints
Файл настроек .htaccess
Настройка robots.txt
Windows 10 | Registry Windows 10 | Windows7: Общие настройки | Windows7: Реестр | Windows7: Реестр faq | Windows7: Настроки сети | Windows7: Безопасность | Windows7: Брандмауэр | Windows7: Режим совместимости | Windows7: Пароль администратора | Память | SDRAM | DDR2 | DDR3 | Quad Band Memory (QBM) | SRAM | FeRAM | Словарь терминов | Video | nVIDIA faq | ATI faq  | Интегрированное видео faq | TV tuners faq | Терминология | Форматы графических файлов | Работа с цифровым видео(faq) | Кодеки faq | DVD faq | DigitalVideo faq | Video faq (Архив) | CPU | HDD & Flash faq | Как уберечь винчестер | HDD faq | Cable faq | SCSI адаптеры & faq | SSD | Mainboard faq | Printer & Scaner | Благотворительность

На главную | Cookie policy | Sitemap