<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>وب نویس &#187; پی اچ پی &#8211; php</title>
	<atom:link href="http://webnevis.net/category/php/feed/" rel="self" type="application/rss+xml" />
	<link>http://webnevis.net</link>
	<description>وب نوشته های يك دانشجوی كامپیوتر</description>
	<lastBuildDate>Thu, 17 Nov 2011 04:01:34 +0000</lastBuildDate>
	<language>fa</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	
		<item>
		<title>آشنایی با سوکت ها &#8211; مهندسی اینترنت</title>
		<link>http://webnevis.net/1390/08/26/%d8%a2%d8%b4%d9%86%d8%a7%db%8c%db%8c-%d8%a8%d8%a7-%d8%b3%d9%88%da%a9%d8%aa-%d9%87%d8%a7-%d9%85%d9%87%d9%86%d8%af%d8%b3%db%8c-%d8%a7%db%8c%d9%86%d8%aa%d8%b1%d9%86%d8%aa/</link>
		<comments>http://webnevis.net/1390/08/26/%d8%a2%d8%b4%d9%86%d8%a7%db%8c%db%8c-%d8%a8%d8%a7-%d8%b3%d9%88%da%a9%d8%aa-%d9%87%d8%a7-%d9%85%d9%87%d9%86%d8%af%d8%b3%db%8c-%d8%a7%db%8c%d9%86%d8%aa%d8%b1%d9%86%d8%aa/#comments</comments>
		<pubDate>Thu, 17 Nov 2011 03:47:38 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[یادداشت ها]]></category>
		<category><![CDATA[آشنایی با پی اچ پی]]></category>
		<category><![CDATA[سوکت ها در پی اچ پی]]></category>
		<category><![CDATA[مهندسی اینترنت]]></category>
		<category><![CDATA[پی اچ پی]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=261</guid>
		<description><![CDATA[برای درس مهندسی اینترنت چند هفته پیش یه ارائه درباره سوکت ها و به کارگیری اون ها در پی اچ پی داشتم &#8230; اسلاید هاش رو اینجا میزارم تا سایر دوستان هم بتونند استفاده کنند ! لینک دانلود امیدوارم که مفید باشه]]></description>
			<content:encoded><![CDATA[<p>برای درس مهندسی اینترنت چند هفته پیش یه ارائه درباره سوکت ها و به کارگیری اون ها در پی اچ پی داشتم &#8230;<br />
اسلاید هاش رو اینجا میزارم تا سایر دوستان هم بتونند استفاده کنند !</p>
<p><a href="http://payamsp.persiangig.com/doc/Mohandesi_Internet.zip" target="_blank">لینک دانلود</a></p>
<p>امیدوارم که مفید باشه</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1390/08/26/%d8%a2%d8%b4%d9%86%d8%a7%db%8c%db%8c-%d8%a8%d8%a7-%d8%b3%d9%88%da%a9%d8%aa-%d9%87%d8%a7-%d9%85%d9%87%d9%86%d8%af%d8%b3%db%8c-%d8%a7%db%8c%d9%86%d8%aa%d8%b1%d9%86%d8%aa/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>کار با element ها در کیک پی اچ پی</title>
		<link>http://webnevis.net/1390/04/29/%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-element-%d9%87%d8%a7-%d8%af%d8%b1-%da%a9%db%8c%da%a9-%d9%be%db%8c-%d8%a7%da%86-%d9%be%db%8c/</link>
		<comments>http://webnevis.net/1390/04/29/%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-element-%d9%87%d8%a7-%d8%af%d8%b1-%da%a9%db%8c%da%a9-%d9%be%db%8c-%d8%a7%da%86-%d9%be%db%8c/#comments</comments>
		<pubDate>Wed, 20 Jul 2011 06:09:55 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[کیک پی اچ پی - CakePHP]]></category>
		<category><![CDATA[CakePHP]]></category>
		<category><![CDATA[آموزش کیک پی اچ پی]]></category>
		<category><![CDATA[پی اچ پی]]></category>
		<category><![CDATA[کیک پی اچ پی]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=255</guid>
		<description><![CDATA[در صفحات مختلف یک وب سایت معمولا بخش هایی وجود دارند که ثابت هستند و در مکان های مختلف تکرار می شوند ، مانند بلوک آخرین مطالب ، لوگوهای دوستان ، فرم خبرنامه و &#8230; ، در این مواقع برای جلوگیری از تکرار کد و راحت تر شدن کار از element ها استفاده می کنیم [...]]]></description>
			<content:encoded><![CDATA[<p>در صفحات مختلف یک وب سایت معمولا بخش هایی وجود دارند که ثابت هستند و در مکان های مختلف تکرار می شوند ، مانند بلوک آخرین مطالب ، لوگوهای دوستان ، فرم خبرنامه و &#8230; ، در این مواقع برای جلوگیری از تکرار کد و راحت تر شدن کار از element ها استفاده می کنیم .</p>
<p>برای ایجاد یک فایل element در کیک پی اچ پی وارد پوشه elements از بخش views شوید و یک فایل با نام دلخواه و پسوند ctp. ایجاد کنید سپس کدهای مد نظرتان را داخل آن وارد کنید ، برای نمایش element مورد نظرتان در سایر فایلهای بخش view هم از دستور زیر استفاده کنید :</p>
<pre class="brush:php">echo $this-&gt;element('element_name');</pre>
<p>برای آشنایی بیشتر با این بخش یک element ایجاد می کنیم که آخرین مطالب موجود در پایگاه داده را نمایش دهد.</p>
<p><span id="more-255"></span></p>
<p>در مرحله اول یک متد در کنترلر مربوط به مطالب تعریف می کنیم که آخرین مطالب را به ما برگرداند</p>
<pre class="brush:php">class PostsController extends AppController
{

	var $name='Posts';

	function index()
	{
		$posts=$this-&gt;Post-&gt;find('all',array('limit'=&gt;10));
		if(isset($this-&gt;params['requested']))
		{
			return $posts;
		}
		else
		{
			$this-&gt;set('posts',$posts);
		}
	}

}</pre>
<p>در اینجا متد index از کنترلر posts رو به شکلی تعریف کردیم که وقتی با استفاده از متد requestAction این متد رو درخواست کردیم مطالب خوانده شده از دیتابیس return شود تا در فایل مربوط به element بتوانیم مورد استفاده قرار دهیم.</p>
<p>حالا در مسیر views/elements یک فایل با نام last_posts.ctp ایجاد کنید و کدهای زیر را داخل آن وارد کنید</p>
<pre class="brush:php">
<h3>Last Posts</h3>

&lt;?php

$posts=$this->requestAction('posts/index');

if(is_array($posts)) :

?&gt;
<ul>

		&lt;?php foreach($posts as $post) : ?&gt;
<li>&lt;?php echo $this->Html->link($post['Post']['title'],array('controller'=>'posts','action'=>'view',$post['Post']['id'])); ?&gt;</li>

		&lt;?php endforeach; ?&gt;
</ul>

&lt;?php endif; ?&gt;
</pre>
<p>حالا هر جا که می خواهید این element رو نمایش بدید از دستور زیر استفاده کنید </p>
<pre class="brush:php" >

echo $this->element('last_posts');
</pre>
<p>موفق باشید</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1390/04/29/%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-element-%d9%87%d8%a7-%d8%af%d8%b1-%da%a9%db%8c%da%a9-%d9%be%db%8c-%d8%a7%da%86-%d9%be%db%8c/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>نمایش آمار بازدید روزانه با PHP</title>
		<link>http://webnevis.net/1389/06/14/statistics-show-daily-with-php/</link>
		<comments>http://webnevis.net/1389/06/14/statistics-show-daily-with-php/#comments</comments>
		<pubDate>Sun, 05 Sep 2010 17:34:30 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[آموزش php]]></category>
		<category><![CDATA[پایگاه داده mysql]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=223</guid>
		<description><![CDATA[اسکریپتی که توی این پست قصد آموزشش رو دارم ، اسکریپت نمایش آمار بازدید امروز ، دیروز و کل بازدید ها هست که توی اکثر سایت ها به اون نیاز هست و مطمئنا به دردتون می خوره. برای شروع کار یک جدول با نام counter با فیلدهای today,yesterday,total,last_visit بسازید. CREATE TABLE IF NOT EXISTS `counter` [...]]]></description>
			<content:encoded><![CDATA[<p>اسکریپتی که توی این پست قصد آموزشش رو دارم ، اسکریپت نمایش آمار بازدید امروز ، دیروز و کل بازدید ها هست که توی اکثر سایت ها به اون نیاز هست و مطمئنا به دردتون می خوره.<br />
برای شروع کار یک جدول با نام counter با فیلدهای today,yesterday,total,last_visit بسازید.</p>
<pre class="brush:php">CREATE TABLE IF NOT EXISTS `counter` (
  `today` INT(11) NOT NULL,
  `yesterday` INT(11) NOT NULL,
  `total` varchar(11) NOT NULL,
  `last_visit` varchar(20) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 ;
</pre>
<p>و یک سطر جدید درج کنید .</p>
<pre class="brush:php">INSERT INTO `counter` (`today`, `yesterday`, `total`, `last_visit`) VALUES
('0', '0', '0', '');
</pre>
<p>نحوه کار به این شکل هست که ابتدا مقدار فیلد last_visit رو که مربوط به تاریخ آخرین بازدید انجام شده از سایت هست رو از دیتابیس می خونیم ، بعد با استفاده از تابع ()date تاریخ فعلی رو بدست میاریم  و با مقدار موجود در last_visit مقایسه می کنیم ، در صورتی که این دو تاریخ باهم برابر باشند مقدار فیلد today رو یکی افزایش میدیم در غیر این صورت متوجه میشیم که آخرین بازدید در روز دیگه ای انجام شده که ما اونو روز قبل در نظر می گیریم و مقدار فیلد yseterday رو برابر با today قرار میدیم و مقدار فیلد today رو مساوی با یک می زاریم و تاریخ آخرین بازید رو هم به روز می کنیم .<br />
توجه داشته باشید که در هر دو حالتی که پیش میاد مقدار فیلد total رو هم یکی افزایش میدیم .<br />
در مرحله آخر هم مقادیر موجود در دیتابیس رو select و چاپ می کنیم .</p>
<p>۱ &#8211; خواندن اطلاعات از دیتابیس</p>
<pre class="brush:php">$con=mysql_connect('localhost','root','');
if(!$con)
	die('error in connect to db');
$select_db=mysql_select_db('test');
if(!$select_db)
	die('error in select db');
$query=mysql_query('select last_visit from counter');
$field=mysql_fetch_array($query);
</pre>
<p>برای آشنایی بیشتر با توابع دیتابیس و کار با اون می تونید <a href="http://webnevis.net/1387/11/18/connect-to-mysql-by-php/" target="_blank">این</a> و <a href="http://webnevis.net/1387/12/28/reading-data-from-mysql-by-php/" target="_blank">این</a> پست رو بخونید .</p>
<p><span id="more-223"></span></p>
<p>۲ &#8211; مقایسه تاریخ آخرین بازدید با تاریخ جاری</p>
<pre class="brush:php">$now=date('Y-m-d');
if($field['last_visit']==$now)
	$query='update counter set today=today+1,total=total+1';
else
	$query="update counter set yesterday=today,today=1,last_visit='$now',total=total+1";
mysql_query($query);
</pre>
<p>3 &#8211; نمایش آمار<br />
برای نمایش مقادیر ذخیره شده هم دوباره از دیتابیس یه select انجام میدیم و مقادیر رو چاپ می کنیم .</p>
<pre class="brush:php">$query=mysql_query('select * from counter');
$field=mysql_fetch_array($query);
echo "

	بازدیدهای امروز : $field[today] 

	بازدیدهای دیروز : $field[yesterday] 

	کل بازدیدها : $field[total]

";
</pre>
<p>کد کامل اسکریپت :</p>
<pre class="brush:php">//read last_visit from db
$con=mysql_connect('localhost','root','');
if(!$con)
	die('error in connect to db');
$select_db=mysql_select_db('test');
if(!$select_db)
	die('error in select db');
$query=mysql_query('select last_visit from counter');
$field=mysql_fetch_array($query);
//Compare dates
$now=date('Y-m-d');
if($field['last_visit']==$now)
	$query='update counter set today=today+1,total=total+1';
else
	$query="update counter set yesterday=today,today=1,last_visit='$now',total=total+1";
mysql_query($query);
//display counter
$query=mysql_query('select * from counter');
$field=mysql_fetch_array($query);
echo "

	بازدیدهای امروز : $field[today] 

	بازدیدهای دیروز : $field[yesterday] 

	کل بازدیدها : $field[total]

";
</pre>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1389/06/14/statistics-show-daily-with-php/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>اعتبارسنجی اطلاعات در کیک پی اچ پی</title>
		<link>http://webnevis.net/1389/01/29/cakephp-validation/</link>
		<comments>http://webnevis.net/1389/01/29/cakephp-validation/#comments</comments>
		<pubDate>Sun, 18 Apr 2010 11:29:03 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[CakePHP]]></category>
		<category><![CDATA[آموزش php]]></category>
		<category><![CDATA[آموزش کیک پی اچ پی]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=209</guid>
		<description><![CDATA[یکی از مهم ترین بخش های هر برنامه بررسی و اعتبارسنجی اطلاعات دریافتی از کاربر هست در واقع با این کار برنامه نویس مطمئن خواهد شد که کاربر داده ای را که مد نظر اوست وارد کرده و با خیال راحت این اطلاعات را مورد استفاده قرار می دهد . برای چک کردن مقادیر در [...]]]></description>
			<content:encoded><![CDATA[<p>یکی از مهم ترین بخش های هر برنامه بررسی و اعتبارسنجی اطلاعات دریافتی از کاربر هست در واقع با این کار برنامه نویس مطمئن خواهد شد که کاربر داده ای را که مد نظر اوست وارد کرده و با خیال راحت این اطلاعات را مورد استفاده قرار می دهد .<br />
برای چک کردن مقادیر در کیک پی اچ پی باید تسلط و آشنایی خوبی با آرایه ها داشته باشید تا هنگام اعتبارسنجی های پیچیده مغزتون هنگ نکنه و به راحتی بتونید کارتون رو جلو ببرید . کدهای مربوط به اعتبارسنجی اطلاعات را باید در کلاس مربوط به  model بنوسید و با تعریف یک خصوصیت به نام validate و اختصاص دادن یک آرایه چند بعدی به آن ، نوع داده های مورد نظرتان را مشخص  نمایید  .</p>
<p>در ساده ترین حالت می تونید برای فیلدهای موردنظرتون که توی جدول تعریف کردید و مقدارش براتون مهم هست یک نوع رو مشخص نمایید</p>
<pre class="brush:php">class User extends AppModel{

	var $name='User';

	var $validate=array(
	'username'=&gt;'alphaNumeric',
	'password'=&gt;'alphaNumeric',
	'email'=&gt;'email'
	);
}</pre>
<p>در این حالت هنگام ذخیره و یا بروز رسانی اطلاعات مقادیر تعیین شده چک می شوند و در صورت مغایرت پیغام مناسب نمایش داده می شود .</p>
<p><span id="more-209"></span></p>
<p>همچنین شما می تونید پیغام هایی که برای هر قسمت نمایش داده می شوند رو تعیین کنید ، برای این کار به شکل زیر عمل کنید</p>
<pre class="brush:php">class User extends AppModel{

	var $name='User';

	var $validate=array(
	'username'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'نام کاربری معتبر نیست'),
	'password'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'رمز عبور معتبر نیست'),
	'email'=&gt;array('rule'=&gt;'email','message'=&gt;'پست الکترونیکی معتبر نیست')
	);
}</pre>
<p>کیک پی اچ پی به صورت پیش فرض یکسری pattern برای چک کردن ایمیل ، ip، تاریخ ،زمان ، کد پستی ، آدرس اینترنتی و سایر مقادیر داره که برای مشاهده کامل این pattern ها می تونید <a href="http://book.cakephp.org/view/134/Core-Validation-Rules" target="_blank">اینجا </a>رو ببینید.</p>
<p>در کیک پی اچ پی این امکان هم وجود داره که شما خودتون یک pattern خاص بنویسید تا مقدار فیلد بر اساس اون چک بشه برای این کار کافیه که فقط pattern دلخواه تون رو به فیلد مورد نظر نسبت بدید</p>
<pre class="brush:php">class User extends AppModel
{
	var $name='User';
	var $useTable='users';
	var $validate=array(
	'username'=&gt;array('rule'=&gt;'/[a-z0-9\-]{3,15}/i','message'=&gt;'نام کاربری معتبر نیست'),
	'password'=&gt;array('rule'=&gt;'/[a-z0-9\-]{6,20}/i','message'=&gt;'رمز عبور معتبر نیست'),
	'email'=&gt;array('rule'=&gt;'/[a-z0-9._\-+]+@[a-zA-Z0-9.\-]+.[a-zA-Z.]+/i','message'=&gt;'پست الکترونیکی معتبر نیست')
	);
}</pre>
<p>برای اینکه یک فیلد رو از چند نظر مورد بررسی قرار بدید کافیه که یک آرایه چند بعدی برای اون فیلد تعریف کنید</p>
<pre class="brush:php">class User extends AppModel
{
	var $name='User';
	var $validate=array(
		'username'=&gt;array(
			'alphaNumeric'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'نام کاربری معتبر نیست'),
			'maxLength'=&gt;array('rule'=&gt;array('maxLength',5),'message'=&gt;'حداکثر طول نام کاربری باید ۵ کاراکتر باشد')
		),
		'password'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'رمز عبور معتبر نیست'),
		'email'=&gt;array('rule'=&gt;'email','message'=&gt;'پست الکترونیکی معتبر نیست')
	);
}</pre>
<p>برای اطلاعات بیشتر در این مورد <a href="http://book.cakephp.org/view/133/Multiple-Rules-per-Field" target="_blank">این </a>صفحه رو بخونید.</p>
<p>همچنین برای تعیین اینکه یک الگو یا pattern در زمان افزودن رکورد چک بشه یا بروزرسانی رکورد می تونید به شکل زیر عمل کنید</p>
<pre class="brush:php">
class User extends AppModel
{
	var $name='User';
	var $validate=array(
		'username'=&gt;array(
			'alphaNumeric'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'نام کاربری معتبر نیست','on'=&gt;'create'),
			'maxLength'=&gt;array('rule'=&gt;array('maxLength',5),'message'=&gt;'حداکثر طول نام کاربری باید ۵ کاراکتر باشد','on'=&gt;'update')
		),
		'password'=&gt;array('rule'=&gt;'alphaNumeric','message'=&gt;'رمز عبور معتبر نیست','on'=&gt;'update'),
		'email'=&gt;array('rule'=&gt;'email','message'=&gt;'پست الکترونیکی معتبر نیست')
	);
}
</pre>
<p>این ها فقط چند مثال برای آشنایی شما با نحوه اعتبار سنجی اطلاعات در کیک پی اچ پی بود و بیشتر سعی کردم مهم ترین موارد رو بگم ، برای اینکه تسلط کاملی بر این موضوع پیدا کنید توصیه می کنم که حتما <a href="http://book.cakephp.org/view/125/Data-Validation" target="_blank">مستندات </a>خود کیک که کامل و گویا هست رو بخونید و <a href="http://lemoncake.wordpress.com/2007/07/03/all-about-validation-in-cakephp-12/" target="_blank">اینجا </a>رو هم یه نگاه بندازید .</p>
<p>موفق باشید</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1389/01/29/cakephp-validation/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>اصول نام گذاری در CakePHP</title>
		<link>http://webnevis.net/1389/01/07/cakephp-conventions/</link>
		<comments>http://webnevis.net/1389/01/07/cakephp-conventions/#comments</comments>
		<pubDate>Fri, 26 Mar 2010 23:09:26 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[CakePHP]]></category>
		<category><![CDATA[آموزش کیک پی اچ پی]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=205</guid>
		<description><![CDATA[کیک پی اچ پی یکی از فریم ورک های محبوب پی اچ پی هست که امکان توسعه سریع برنامه های تحت وب رو به یک توسعه دهنده میده و کلا کار کردن با این فریم ورک خیلی لذت بخش و دوست داشتنی هست به این شرط که توسعه دهنده تسلط تقریبا کاملی بر روی این [...]]]></description>
			<content:encoded><![CDATA[<p>کیک پی اچ پی یکی از فریم ورک های محبوب پی اچ پی هست که امکان توسعه سریع برنامه های تحت وب رو به یک توسعه دهنده میده و کلا کار کردن با این فریم ورک خیلی لذت بخش و دوست داشتنی هست به این شرط که توسعه دهنده تسلط تقریبا کاملی بر روی این فریم ورک داشته باشه .<br />
برای آشنایی بیشتر و شروع کار با این فریم ورک سایت خود <a href="http://cakephp.org/" target="_blank">CakePHP</a> مستندات خوبی رو ارائه کرده همچنین توصیه می کنم که <a href="http://www.google.com/url?sa=t&amp;source=web&amp;ct=res&amp;cd=3&amp;ved=0CBEQFjAC&amp;url=http%3A%2F%2Fnet.tutsplus.com%2Ftutorials%2Fphp%2Fgetting-started-with-cakephp%2F&amp;ei=qV2sS82gBsmr4Qb3kM2vDw&amp;usg=AFQjCNGcZwASfUxdTN-uEaSrP5SK7BlYKg&amp;sig2=uHh2cbN1T5PL7aQtkOkx2Q" target="_blank">این</a> آموزش از سایت <a href="http://net.tutsplus.com/" target="_blank">tutsplus </a>رو هم بخونید ، متاسفانه منبع فارسی تو این زمینه خیلی کم هست و اگر دنبال منابع فارسی برای شروع یادگیری کیک هستید وبلاگ <a href="http://1barnamenevis.ir/" target="_blank">یک برنامه نویس</a> به تازگی یک دوره آموزشی کیک رو شروع کرده ، وبلاگ <a href="http://weblog.alvanweb.com/" target="_blank">الوان وب</a> هم آموزش های خوبی رو تو این زمینه داره و توی <a href="http://forum.cakephp.ir/index.php" target="_blank">انجمن فارسی توسعه کیک</a> هم می تونید مطالب مفیدی رو پیدا کنید .<br />
بعد از نصب و راه اندازی کیک و آشنایی با ساختار اون ، مهم ترین چیزی که باید بدونید اصول نام گذاری کلاس ها و فایل ها توی این فریم ورک هست پس به ادامه مطلب توجه کنید .</p>
<p><strong> Controller  :<br />
</strong>نام controller  باید به صورت جمع باشد و برای نام گذاری کلاس کنترلر کلمه controller رو باید در انتهای نام کلاس اضافه کنید ، برای مثال ProductsController ، اگر تعداد کلمات نام کلاستون بیشتر از یک کلمه باشد باید حرف اول هر کلمه رو به صورت بزرگ بنویسید برای مثال OnlineProductsController  .<br />
فایلی که کلاس کنترلر را در آن می نویسیم همنام با نام کلاس کنترلر هست با این تفاوت که کلمه controller با یک underline از نام کلاس جدا می شود برای مثال اگر اسم کلاس مون ProductsController باشه نام فایل باید products_controller.php باشه و برای نام هایی که بیش از یک کلمه دارند کلمات با یک underline از هم جدا می شوند مثلا اگر اسم کلاسمون به صورت OnlineProductsController باشه اسم فایل کنترلر باید online_products_controller.php باشه ، همچنین توجه داشته باشید که تمام حروف نام فایل به صورت کوچک نوشته می شوند .</p>
<p>فایل : app/controllers/products_controller.php</p>
<pre class="brush:php">class ProductsController extends AppController {
 var $name="Products";
}</pre>
<p><span id="more-205"></span><strong>Model :</strong><br />
نام کلاس model به صورت مفرد نوشته می شود برای مثال Product و اگر تعداد کلمات بیش از یک کلمه باشد حرف اول هر کلمه به صورت بزرگ نوشته می شود برای مثال OnlineProduct ، فایل model همنام با نام کلاس model هست با این تفاوت که اگر تعداد کلمات زیاد باشد باید کلمات با underline از هم جدا شوند برای مثال online_product.php .</p>
<p>فایل : app/models/product.php</p>
<pre class="brush:php">class Product extends AppModel {
 var $name="Product";
}</pre>
<p><strong>Database Table :<br />
</strong>نام جداول دیتابیستون هم باید به صورت جمع باشه و کلمات با استفاده از underline از هم جدا شوند . برای مثال اگر نام model شما product باشه نام جدول باید products باشه .<br />
البته شما می تونید نام جدولتون رو به صورت دلخواه انتخاب کنید که در این صورت باید در کلاس model این موضوع رو مشخص نمایید برای مثال اگر اسم جدول تون رو mytable  انتخاب کنید در این صورت در کلاس model باید خصوصیت useTable رو برابر با mytable قرار بدید.</p>
<pre class="brush:php">class Product extends AppModel {
 var $name="Product";
 var $useTable='mytable';
}</pre>
<p><strong>View :</strong><br />
فایل های مربوط به بخش view در مسیر app/views قرار می گیرند و برای هر controller باید یک پوشه با نام controller ایجاد کنید و سپس برای متد موردنظرتون فایل view رو ایجاد نمایید ، برای مثال اگر نام controller ما ProductsController باشه که دارای متد index  هست ابتدا باید یک پوشه با نام products در مسیر app/views ایجاد نماییم و سپس برای متد مورد نظرمون فایل view رو ایجاد کنیم که در اینجا index.ctp هست ، توجه داشته باشید که فرمت فایل های view باید ctp. باشه .</p>
<p>امیدوارم که براتون مفید باشه ، موفق باشید</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1389/01/07/cakephp-conventions/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>ساخت صفحات وب به کمک تابع include در PHP</title>
		<link>http://webnevis.net/1388/09/14/build-web-pages-with-include-in-php/</link>
		<comments>http://webnevis.net/1388/09/14/build-web-pages-with-include-in-php/#comments</comments>
		<pubDate>Sat, 05 Dec 2009 15:31:44 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[آموزش php]]></category>
		<category><![CDATA[برنامه نویسی]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=199</guid>
		<description><![CDATA[توی این پست قصد دارم نحوه ساخت راحت تر صفحات وب رو برای وب سایت هایی که با استفاده از PHP ایجاد می کنیم آموزش بدم . توی اکثر صفحاتی که برای یک وب سایت ایجاد می کنیم معمولا فقط بخش وسط صفحه تغییر میکنه و header و footer و sidebar به صورت ثابت توی [...]]]></description>
			<content:encoded><![CDATA[<p>توی این پست قصد دارم نحوه ساخت راحت تر صفحات وب رو برای وب سایت هایی که با استفاده از PHP ایجاد می کنیم آموزش بدم .<br />
توی اکثر صفحاتی که برای یک وب سایت ایجاد می کنیم معمولا فقط بخش وسط صفحه تغییر میکنه و header و footer و sidebar به صورت ثابت توی بقیه صفحه ها تکرار میشن به همین خاطر می تونیم این سه قسمت رو توی سه تا فایل جداگانه قرار بدیم و توی هر صفحه ای که ایجاد می کنیم این فایل ها رو include کنیم و سرعت انجام کار رو بالا ببریم و وقتی هم که می خوایم تم سایت رو تغییر بدیم کارمون راحت تر میشه .</p>
<p><span id="more-199"></span></p>
<p>بر فرض اگه کد تمپلیت ما به صورت زیر باشه</p>
<pre class="brush:php">&lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&gt;
&lt;html xmlns="http://www.w3.org/1999/xhtml"&gt;
&lt;head&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8" /&gt;
    &lt;link type="text/css" rel="stylesheet" href="style.css" media="screen"  /&gt;
    &lt;title&gt;Site Title&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;div id="main" &gt;
    	&lt;!-- header --&gt;
    	&lt;div id="header" &gt;&lt;/div&gt;
        &lt;div id="menu" &gt;
     		&lt;a href="home.php" &gt;Home&lt;/a&gt;|
            &lt;a href="About.php" &gt;About&lt;/a&gt;|
            &lt;a href="Contact.php" &gt;Contact&lt;/a&gt;
        &lt;/div&gt;
        &lt;!-- /header --&gt;

        &lt;div id="content" &gt;&lt;/div&gt;

        &lt;!-- sidebar --&gt;
        &lt;div id="sidebar" &gt;&lt;/div&gt;
        &lt;!-- /sidebar --&gt;

        &lt;div class="clear" &gt;&lt;/div&gt;

        &lt;!-- footer --&gt;
    	&lt;div id="footer" &gt;&lt;/div&gt;
        &lt;!-- /footer --&gt;
    &lt;/div&gt;
&lt;/body&gt;
&lt;/html&gt;</pre>
<p>کد های زیر رو از تمپلیت اصلی سایت جدا کرده و با نام header.php ذخیره می کنیم .</p>
<pre class="brush:php">&lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&gt;
&lt;html xmlns="http://www.w3.org/1999/xhtml"&gt;
&lt;head&gt;
    &lt;meta http-equiv="Content-Type" content="text/html; charset=utf-8" /&gt;
    &lt;link type="text/css" rel="stylesheet" href="style.css" media="screen"  /&gt;
    &lt;title&gt;Site Title&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;div id="main" &gt;
    	&lt;!-- header --&gt;
    	&lt;div id="header" &gt;&lt;/div&gt;
        &lt;div id="menu" &gt;
     		&lt;a href="home.php" &gt;Home&lt;/a&gt;|
            &lt;a href="About.php" &gt;About&lt;/a&gt;|
            &lt;a href="Contact.php" &gt;Contact&lt;/a&gt;
        &lt;/div&gt;
        &lt;!-- /header --&gt;</pre>
<p>کدهای زیر رو هم با نام sidebar.php ذخیره می کنیم</p>
<pre class="brush:php">        &lt;!-- sidebar --&gt;
        &lt;div id="sidebar" &gt;&lt;/div&gt;
        &lt;!-- /sidebar --&gt;</pre>
<p>و کدهای زیر رو با نام footer.php ذخیره می کنیم</p>
<pre class="brush:php">        &lt;div class="clear" &gt;&lt;/div&gt;

        &lt;!-- footer --&gt;
    	&lt;div id="footer" &gt;&lt;/div&gt;
        &lt;!-- /footer --&gt;
    &lt;/div&gt;
&lt;/body&gt;
&lt;/html&gt;</pre>
<p>حالا وقتی میخوایم یک صفحه جدید ایجاد کنیم فقط کافیه که این سه تا فایل رو include کنیم و اطلاعات مربوط به صفحه جدید رو وارد کنیم .</p>
<pre class="brush:php">&lt;?php include_once('header.php'); ?&gt;
&lt;div id="content" &gt; Content  &lt;/div&gt;
&lt;?php include_once('sidebar.php'); ?&gt;
&lt;?php include_once('footer.php'); ?&gt;</pre>
<p>برای اینکه بتونیم عنوان هر صفحه رو هم  مشخص کنیم تگ مربوط به عنوان صفحه رو توی فایل header.php به صورت زیر تغییر میدیم</p>
<pre class="brush:php">&lt;title&gt; &lt;?php echo $pagetitle; ?&gt; &lt;/title&gt;</pre>
<p>و توی هر صفحه ای که ایجاد می کنیم قبل از include کردن فایل header.php این متغیر رو مقداردهی می کنیم تا به عنوان title صفحه قرار بگیرد .</p>
<pre class="brush:php">&lt;?php
$pagetitle='Contact';
include_once('header.php');
?&gt;
&lt;div id="content" &gt; Contact Form  &lt;/div&gt;
&lt;?php include_once('sidebar.php'); ?&gt;
&lt;?php include_once('footer.php'); ?&gt;</pre>
<p>موفق باشید</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1388/09/14/build-web-pages-with-include-in-php/feed/</wfw:commentRss>
		<slash:comments>15</slash:comments>
		</item>
		<item>
		<title>معرفی کلاس TableGear</title>
		<link>http://webnevis.net/1388/09/03/introduction-class-tablegear/</link>
		<comments>http://webnevis.net/1388/09/03/introduction-class-tablegear/#comments</comments>
		<pubDate>Tue, 24 Nov 2009 16:50:40 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[پی اچ پی - php]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=192</guid>
		<description><![CDATA[TbleGear یک کلاس فوق العاده قوی برای نمایش اطلاعات جدول های دیتابیس و انجام عملیات روی رکوردهاست که کار کردن باهاش خیلی راحته و باعث میشه تا سرعت انجام کارتون بالا بره و کد کمتری بزنید این کلاس امکان ویرایش و حذف رکوردهای جدول رو به صورت کاملا ای جکسی به شما میده و کاربر [...]]]></description>
			<content:encoded><![CDATA[<p>TbleGear یک کلاس فوق العاده قوی برای نمایش اطلاعات جدول های دیتابیس  و انجام عملیات روی رکوردهاست که کار کردن باهاش خیلی راحته و باعث میشه تا سرعت انجام کارتون بالا بره و کد کمتری بزنید این کلاس امکان ویرایش و حذف رکوردهای جدول رو به صورت کاملا ای جکسی به شما میده و کاربر می تونه با کلیک روی هر فیلد از جدول،اطلاعات اون فیلد رو ویرایش کنه همچنین امکانات زیاد دیگه ای مثل صفحه بندی کردن ، validate کردن اطلاعات دریافتی از کاربر و&#8230; رو به شما میده که اگه یه سر به <a href="http://andrewplummer.com/demos/tablegear/" target="_blank">دمویی</a> که <a href="http://andrewplummer.com" target="_self"><a href="http://andrewplummer.com/code/tablegear/" target="_blank">سایتش</a> </a>ارائه داده بزنید متوجه این امکانات میشید،توی <a href="http://andrewplummer.com/code/tablegear/" target="_blank">سایت</a> رسمی این کلاس هم توضیحات کاملی  در مورد نحوه استفاده ازش وجود داره .<br />
برای کار کردن با اطلاعات فارسی باید توی فایل اصلی کلاس که توی پوشه src قرار داره داخل متد connect دو تا کوئری زیر رو بعد از دستور mysql_connect قرار بدید تا اطلاعات فارسی رو به صورت درست ذخیره کنه و نمایش بده .</p>
<pre class="brush: php">		mysql_query("SET CHARACTER SET utf8;",$this-&gt;connection);
		mysql_query("SET SESSION collation_connection = 'utf8_persian_ci'",$this-&gt;connection);</pre>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1388/09/03/introduction-class-tablegear/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>چند نکته در برنامه نویسی به زبان php &#8211; قسمت دوم</title>
		<link>http://webnevis.net/1388/04/27/few-tips-in-php-programing-part-2/</link>
		<comments>http://webnevis.net/1388/04/27/few-tips-in-php-programing-part-2/#comments</comments>
		<pubDate>Sat, 18 Jul 2009 02:23:18 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[آموزش php]]></category>

		<guid isPermaLink="false">http://webnevis.net/1388/04/27/%da%86%d9%86%d8%af-%d9%86%d9%83%d8%aa%d9%87-%d8%af%d8%b1-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%d9%8a%d8%b3%d9%8a-%d8%a8%d9%87-%d8%b2%d8%a8%d8%a7%d9%86-php-%d9%82%d8%b3%d9%85%d8%aa-%d8%af/</guid>
		<description><![CDATA[- سرعت پردازش تابع echo در مقایسه با تابع print بیشتر هست و خودم هم همیشه از این تابع استفاده می کنم در ضمن بهتره که به جای استفاده از تابع echo به شکل زیر echo 'my'.'name'.'is'.$name; از این تابع به صورت زیر استفاده کنید echo 'my','name','is',$name; همچنین در مورادی به شکل زیر echo 'string [...]]]></description>
			<content:encoded><![CDATA[<p>- سرعت پردازش تابع echo در مقایسه با تابع print بیشتر هست و خودم  هم همیشه از این تابع استفاده می کنم در ضمن  بهتره که به جای استفاده از تابع echo به شکل زیر</p>
<pre class="brush: php" >
echo 'my'.'name'.'is'.$name;
</pre>
<p>از این تابع به صورت زیر استفاده کنید</p>
<pre class="brush: php">echo 'my','name','is',$name;</pre>
<p>همچنین در مورادی  به شکل زیر</p>
<pre class="brush: php">echo 'string 1';
echo 'string 2';
echo 'string 3';
</pre>
<p>برای بالا بردن سرعت اجرای برنامه بهتره که این رشته ها یا خروجی ها را در یک متغیر بریزید و تنها همون متغیر رو چاپ کنید</p>
<pre class="brush: php">$output='string 1';
$output.='string 2';
$output.='string 3';
echo $output;
</pre>
<p><span id="more-149"></span></p>
<p>- در مواردی مثل  زیر</p>
<pre class="brush: php">$a=array('a','b','c','d','e','f','g','h','i');
for($i=0;$i&lt;count($a);$i++)
echo $a[$i];
</pre>
<p>برای جلوگیری از اجرا شدن مکرر تابع count بهتره که این تابع رو یکبار صدا بزنیم و مقدار اون رو داخل یک متغیر برزیم</p>
<pre class="brush: php">$a=array('a','b','c','d','e','f','g','h','i');
$len=count($a);
for($i=0;$i&lt;$len;$i++)
echo $a [$i];
</pre>
<p>- برای بالا بردن قابلیت حمل برنامه تون بهتره که از  php?&gt; به جای  ?&gt; استفاده کنید چون ممکنه که در برخی سرورها این امکان غیر فعال باشه .</p>
<p>- استفاده از @ برای جلوگیری از نمایش خطا باعث کاهش سرعت اجرای برنامه می شه .</p>
<p>- پس از استفاده از آرایه های بزرگ و متغیرهای سراسری برای آزاد سازی حافظه بهتره که اونها رو unset کنید ، با این کار سرعت پردازش بالا میره .</p>
<p>نکاتی که توی این پست و <a href="http://webnevis.net/1388/04/21/few-tips-in-php-programing/" target="_blank">پست قبلی</a> نوشتم بیشتر برای بالا بردن سرعت اجرای برنامه و بهینه کردن کدها بود امیدوارم که مفید باشه .</p>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1388/04/27/few-tips-in-php-programing-part-2/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>چند نکته در برنامه نویسی به زبان php</title>
		<link>http://webnevis.net/1388/04/21/few-tips-in-php-programing/</link>
		<comments>http://webnevis.net/1388/04/21/few-tips-in-php-programing/#comments</comments>
		<pubDate>Sun, 12 Jul 2009 19:33:28 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[آموزش php]]></category>

		<guid isPermaLink="false">http://webnevis.net/1388/04/21/%da%86%d9%86%d8%af-%d9%86%da%a9%d8%aa%d9%87-%d8%af%d8%b1-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%86%d9%88%db%8c%d8%b3%db%8c-%d8%a8%d9%87-%d8%b2%d8%a8%d8%a7%d9%86-php/</guid>
		<description><![CDATA[- عبارات و مقدار هایی که بین دابل کوتیشن قرار می گیرند به هنگام اجرای برنامه بر روی آنها پردازش انجام می شود ، بنابراین بهتر است مقدار هایی که فقط شامل متن هستند رو بین سینگل کوتیشن قرار دهیم مخصوصا در مواردی که رشته مورد نظرمون طولانی هست. پس به جای استفاده از حالت [...]]]></description>
			<content:encoded><![CDATA[<p>- عبارات و مقدار هایی که بین دابل کوتیشن قرار می گیرند به هنگام اجرای برنامه بر روی آنها پردازش انجام می شود ، بنابراین بهتر است  مقدار هایی که فقط شامل  متن هستند رو بین سینگل کوتیشن قرار دهیم مخصوصا در مواردی که رشته مورد نظرمون طولانی هست.<br />
پس به جای استفاده از حالت زیر</p>
<pre class="brush: php">$msg="please enter all fields";</pre>
<p>بهتره که به شکل زیر عمل کنید</p>
<pre class="brush: php">$msg='please enter all fileds';</pre>
<p>- اگر بخواهیم مقادیر موجود در یک آرایه رو داخل دیتابیس وارد کنیم به جای استفاده از روش زیر</p>
<pre class="brush: php">$arr=array('ali','mohammad','pouya');
foreach($arr as $val)
mysql_query("insert into my_tbl values('$val')");</pre>
<p><span id="more-141"></span><br />
بهتره که از دستورهای زیر استفاده کنید</p>
<pre class="brush: php">$arr=array('ali','mohammad','pouya');
$values=array();
foraech($arr as $val)
$values[]='("'.$val.'")';
$query='insert into my_tbl values'.implode(',' ,$values);
mysql_query($query);</pre>
<p>اگر از حالت اول استفاده کنید با هر بار چرخش حلقه یک کوئری اجرا میشه و مقدار مورد نظر از آرایه به جدولمون وارد میشه اما در روش دوم دستور اس کیو ال مون رو به صورت پویا می نویسم و تنها با اجرای یک کوئری مقادیر مورد نظرمون رو وارد جدول می کنیم که باعث میشه تا سرعت برنامه بالا بره .</p>
<p>- مقادیری که از کاربر دریافت می کنید رو بی دلیل در متغیر اضافی قرار ندید یا آن را در داخل چند متغیر کپی نکنید تا حافظه کمتری مورد استفاده قرار بگیرد و برنامه با سرعت بیش تری اجرا شود .<br />
بنابراین به جای استفاده از روش زیر</p>
<pre class="brush: php">$a=htmlspecialchars($_GET['name']);
echo 'your name is'.$a;</pre>
<p>بهتره که از دستور زیر استفاده کنیم</p>
<pre class="brush: php">echo 'your name is'.htmlspecialchars($_GET['name']);</pre>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1388/04/21/few-tips-in-php-programing/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>خواندن اطلاعات از پایگاه داده mysql با php</title>
		<link>http://webnevis.net/1387/12/28/reading-data-from-mysql-by-php/</link>
		<comments>http://webnevis.net/1387/12/28/reading-data-from-mysql-by-php/#comments</comments>
		<pubDate>Wed, 18 Mar 2009 13:38:37 +0000</pubDate>
		<dc:creator>پیام</dc:creator>
				<category><![CDATA[برنامه نویسی]]></category>
		<category><![CDATA[پی اچ پی - php]]></category>
		<category><![CDATA[آموزش php]]></category>
		<category><![CDATA[پایگاه داده mysql]]></category>

		<guid isPermaLink="false">http://webnevis.net/?p=102</guid>
		<description><![CDATA[توی پست &#8221; آموزش ارتباط با پایگاه داده mysql در php &#8221; نحوه برقراری ارتباط با پایگاه داده mysql و اجرای دستورات sql رو توضیح دادم ، توصیه می کنم که ابتدا به این پست یک نگاه بندازید. در این آموزش فرض رو بر این بگیرید که یک پایگاه داده با نام test داریم که [...]]]></description>
			<content:encoded><![CDATA[<p>توی پست &#8221; آموزش ارتباط با پایگاه داده mysql  در php &#8221;  نحوه برقراری ارتباط با پایگاه داده mysql و اجرای دستورات sql  رو توضیح دادم ، توصیه می کنم که ابتدا به این پست یک نگاه بندازید.</p>
<p>در این آموزش فرض رو بر این بگیرید که یک پایگاه داده با نام test داریم که دارای یک جدول با نام mytable هست و این جدول ۳ فیلد با نام های   name ، id  و email  دارد.<br />
برای خواندن اطلاعات از پایگاه داده ابتدا شما باید یک دستور sql بنویسید ، در زبان sql برای خواندن اطلاعات از پایگاه داده از دستور select استفاده می شود.</p>
<p style="text-align: left;">;   شرط WHERE   نام جدول  FROM  نام فیلدهای مورد نظر  SELECT</p>
<p style="text-align: right;">بعد از دستور select باید نام فیلدهایی که می خواهید انتخاب کنید رو بنویسید و اگر قصد انتخاب همه فیلدها رو دارید می تونید از کاراکتر * استفاده کنید .<br />
همچنین برای انتخاب اطلاعات یک قسمت از جدول  باید از دستور where استفاده کنید و بعد از آن شرط مورد نظرتون رو بنویسید .</p>
<pre class="brush: php">SELECT * FROM mytable WHERE id &gt;10;
SELECT name,email FROM mytable;</pre>
<p style="text-align: right;"><span id="more-102"></span></p>
<p style="text-align: right;">ابتدا با پایگاه داده  ارتباط برقرار می کنیم و سپسس دیتابیس خودمون رو انتخاب می کنیم .</p>
<pre class="brush: php">$con=mysql_connect('localhost','root',' ');
mysql_select_db('test',$con);
</pre>
<p>سپس در داخل متغیر query کوئری خود رو مینویسیم و با استفاده از mysql_query آن را اجرا می کنیم.</p>
<pre class="brush: php">$query="SELECT * FROM mytable";
$select=mysql_query($query);
</pre>
<p style="text-align: right; ">حالا باید از حلقه ها برای خواندن اطلاعات به همراه یکی از دستورات زیر استفاده کنیم.</p>
<p style="text-align: right; ">mysql_fetch_row : این تابع اطلاعات انتخاب شده  رو به صورت یک آرایه عددی بر می گرداند.<br />
mysql_fetch_assoc : این تابع اطلاعات انتخاب شده  رو به صورت یک آرایه انجمنی بر می گرداند.<br />
mysql_fetch_array :  آرایه ای را بر می گرداند که هم به صورت انجمنی است و هم عددی  .<br />
mysql_fetch_object : این تابع هم اطلاعات انتخاب شده رو به صورت یک شی بر می گرداند .</p>
<p style="text-align: right; ">هر چهار تابع بالا نتیجه کوئری اجرا شده( متغیر select ) رو به عنوان پارامتر دریافت می کنند.</p>
<pre class="brush: php">while($row=mysql_fetch_array($select)){
echo $row['id'].' - '.$row['name'].' - '.$row['email'].'&lt;br&gt;';
}
</pre>
<p style="text-align: right;">در این جا از یک حلقه while استفاده کردیم و این حلقه تا زمانی که متغیر row دارای مقدار باشد اجرا می شود.<br />
اگر از تابع mysql_fetch_object استفاده کنید برای دسترسی به اطلاعات باید به شکل زیر عمل  نمایید</p>
<pre class="brush: php">while($row=mysql_fetch_object($select)){
echo $row-&gt;id.' - '.$row-&gt;name.' - '.$row-&gt;email.'&lt;br&gt;';
}
</pre>
<p style="text-align: right;">در آخر هم ارتباط ایجاد شده با پایگاه داده را قطع می کنیم.</p>
<pre class="brush: php">mysql_close($con);</pre>
<p style="text-align: right;">کد کامل :</p>
<pre class="brush: php">$con=mysql_connect('localhost','root',' ');
mysql_select_db('test',$con);
$query="SELECT * FROM mytable";
$select=mysql_query($query);
while($row=mysql_fetch_array($select)){
echo $row['id'].' - '.$row['name'].' - '.$row['email'].'&lt;br&gt;';
}
mysql_close($con);
</pre>
]]></content:encoded>
			<wfw:commentRss>http://webnevis.net/1387/12/28/reading-data-from-mysql-by-php/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
	</channel>
</rss>

