Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

Пользователей: 13,370
новичок: dogoco6
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование литейного цеха на GPSS + Пояснительная записка
Компьютерный магазин на Turbo Pascal (База данных) + Пояснительная записка
Файл записей с выводом обратного заголовка на Turbo Pascal

Используем базу данных MySQL
Автор: Бардин Павел,
Источник: www.proger.ru

MySql - Система Управления Базами Данных (СУБД). Основное отличие от всех остальных СУБД это то, что она является бесплатной. В силу того, что mysql бесплатна, она поддерживается очень многими хостинг провайдерами.

Здесь я расскажу как связать php и mysql т.е. как получить данные из базы данных mysql в php скрипт.

Ну вообще-то это не так сложно. Всё, что нужно знать:
Хост - адрес сервера баз данных mysql
Имя базы данных
Имя пользователя
Пароль - пароль для доступа к БД
Некоторые sql команды

Далее я буду предполагать, что у вас уже заведена база данных на сервере хостера или на домашнем компьютере (mysql можно скачать с сайта http://mysql.com).
Итак, алгоритм такой:
Устанавливаем соединение с сервером
Выбираем нужную базу данных
Делаем запрос к серверу баз данных (sql запрос)
Обрабатываем результат запроса, если это необходимо
Закрываем соединение (отключаемся от сервера БД)

По части php, чтобы работать с БД надо знать несколько функций (полный список смотри в php мануале).
mysql_connect();
mysql_select_db();
mysql_query();
mysql_fetch_array();
mysql_close();

Это тот минимум, который позволит вам устанавливать соединение с сервером mysql, выбирать базы данных и делать запросы к серверу баз данных.
Для справки!

Все php функции которые предназначены для работы с базой данных mysql имеют префикс mysql_

Я не буду рассматривать синтаксис каждой функции. Надеюсь у вас есть php manual (его можно скачать с сайта http://php.net). Рассмотрим эти функции в деле т.е. на примере.

Допустим в нашей базе данных храниться одна таблица со следующей структурой:
имя поля тип(длина) описание
id целый(2) уникальный номер
name символьный(100) имя
tel символьный(20) телефон

Таблица имеет имя: customer, а наша база данных называется database.

Допустим, что ваши данные для подключения к серверу mysql Такие:
Хост: localhost
Имя пользователя: guest
Пароль: mypassword

Для начала необходимо создать нашу таблицу customer. Напишем скрипт который создаст в базе данных database таблицу customer. Назовём файлик как install.php.
Файл install.php

// Данные для mysql сервера
$dbhost = "localhost"; // Хост
$dbuser = "guest"; // Имя пользователя
$dbpassword = "mypassword"; // Пароль
$dbname = "database"; // Имя базы данных

// Подключаемся к mysql серверу
$link = mysql_connect($dbhost, $dbuser, $dbpassword);

// Выбираем нашу базу данных
mysql_select_db($dbname, $link);

// Создаём таблицу customer
// т.е. делаем sql запрос
$query = "create table customer (id int(2) primary key
auto_increment, name varchar(100), tel varchar(20))";
mysql_query($query, $link);

// Закрываем соединение
mysql_close($link)

?>

Функция mysql_connect() возвращает идентификатор соединения. Этот идентификатор необходимо указывать во всех mysql функциях. Можно провести аналогию с указателем на файл (file pointer), который используется функциями по работе с файлами. В параметрах функции мы указали хост, имя пользователя и пароль к базе данных.

На сервере mysql храниться не только ваша база данных. Сервер может обслуживать тысячи таких баз данных.

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

Выбор базы данных осуществляется функцией mysql_select_db(). В параметрах указывается: имя требуемой базы данных $dbname и идентификатор соединения $link, который мы получили с помощью функции mysql_connect().

После того как мы подключились к серверу mysql и выбрали нашу базу данных, мы делаем sql запрос.

Литературу по языку sql вы найдёте на сайте mysql.ru. В запросе указываем, что мы хотим создать таблицу с именем customer и со структурой приведённой в таблице выше. Запрос к серверу mysql осуществляется с помощью функции mysql_query(). В параметрах указывается сам запрос $query и идентификатор соединения $link.

И, наконец, отключаемся от сервера (закрываем соединение) функцией mysql_close().

В параметрах указываем идентификатор того соединения, которое нужно закрыть.
Для справки!

На самом деле скрипт может устанавливать несколько соединений с сервером mysql.

Всё зависит от хостинга на котором вы сидите.

Если вы всё сделали правильно, то на сервере mysql в вашей базе данных, появится таблица customer.

После того как мы создали таблицу, её надо заполнить т.е. записать в нёё какие-нибудь данные (записи).

Напишем скрипт, который будет добавлять запись в нашу таблицу. Назовём файл скрипта как insert.php.
Файл insert.php

// Данные для mysql сервера
$dbhost = "localhost"; // Хост
$dbuser = "guest"; // Имя пользователя
$dbpassword = "mypassword"; // Пароль
$dbname = "database"; // Имя базы данных

// Подключаемся к mysql серверу
$link = mysql_connect($dbhost, $dbuser, $dbpassword);

// Выбираем нашу базу данных
mysql_select_db($dbname, $link);

// Добавляем запись в нашу таблицу customer
// т.е. делаем sql запрос
$query = "insert into customer values(0,'Иванов Иван Иванович',
'(095) 555-55-55')";

mysql_query($query, $link);

// Закрываем соединение
mysql_close($link);

?>

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

Теперь когда мы умеем записывать данные в базу данных, перейдём к процедуре запроса данных из базы mysql.

Для этого напишем скрипт и назовём файлик select.php.
Файл select.php

// Данные для mysql сервера
$dbhost = "localhost"; // Хост
$dbuser = "guest"; // Имя пользователя
$dbpassword = "mypassword"; // Пароль
$dbname = "database"; // Имя базы данных

// Подключаемся к mysql серверу
$link = mysql_connect($dbhost, $dbuser, $dbpassword);

// Выбираем нашу базу данных
mysql_select_db($dbname, $link);

// Добавляем запись в нашу таблицу customer
// т.е. делаем sql запрос
$query = "select * from customer";

// Запрашиваем
$result = mysql_query($query, $link);

while($rows = mysql_fetch_array($result, mysql_assoc))
{
printf("id:%d, name:%s, tel:%s",
rows['id'],rows['name'],rows['tel']);
}

// Закрываем соединение
mysql_close($link);

?>

Ну тут... всё понятно :) :) :) Естественно изменилась строка запроса $query, которая теперь содержит sql-оператор select. Так же добавился небольшой код while() { .... }.

Скажу только, что функция mysql_fetch_array() обрабатывает результат запроса и возвращает массив полей текущей! Внимание! текущей строки результата.

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

После того как функция mysql_fetch_array() обработает все строки результата, она вернёт значение false и тогда цикл while() - не выполниться.

Тут в цикле используем функцию printf(). Она очень похожа на эту же функцию в языке c.

Справку по функции printf() можете посмотреть в php мануале.

Надеюсь моя статья хоть немного помогла вам понять связь php и mysql.
Опубликовал Kest November 02 2008 14:24:54 · 2 Комментариев · 18749 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Дмитрий December 03 2010 11:42:40
На троечку статья. Для новичка остается множество неясных моментов, что же касается остальных, то они и так умеют пользоваться базами. ПО сути по всем приведенным функциям после статьи придется смотреть либо мануалы, либо другие статьи.smiley
Дмитрий January 08 2017 05:02:41
Согласен с первым комментатором. Первый скрипт заработал - создалась таблица, второй заработал - заполнилась таблица, третий не работает, написано "Справку по функции printf() можете посмотреть в php мануале. " . И так все скопипастили статью. Ну найду я про функцию printf(), это что-то изменит? я вместо этой функции вставлял другие, например "echo 10;", она тоже не работает, потому, что там что-то не так. а я новичок, разобраться не могу, в чем ошибка. Это единственная статья, из которой хоть что-то с БД заработало.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
SMLPack v1.0
Приемы программир...
Программирование ...
База данных фильм...
Sztransppanel
EditButton
Иллюстрированный ...
БД сеть компьютер...
Borland Delphi 6....
Программирование ...
Последнее загруж...
Панель Календарь
Dealer
Редактор текста (...
Калькулятор [Исхо...
AJAX и PHP. разра...
Создание меню на ...
Delphi 6/7 базы д...
Print Grid
Динамические за...

Топ загрузок
Приложение Клие... 100774
Delphi 7 Enterp... 97836
Converter AMR<-... 20268
GPSS World Stud... 17014
Borland C++Buil... 14191
Borland Delphi ... 10291
Turbo Pascal fo... 7374
Калькулятор [Ис... 5984
Visual Studio 2... 5207
Microsoft SQL S... 3661
Случайные статьи
Окно редактора кол...
Информационные и с...
Использование кома...
Стандартные процед...
Класс TPaintBox
Перечный шираз
Связываемые таблиц...
Ud и lima
Сигнатуры
5.1. От псевдокода...
Создание экземпляр...
Управление хранени...
Protocol) 355IAS (...
Яндекс учитывает м...
Изображения для пр...
Есть еще несколько...
Планирование справ...
однасторона
More Book Stuff
Непроизводительные...
Моделирование элек...
Презентации Prezi
Invalid floating-p...
Виртуальный гемблинг
Металлический штак...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?