MySQL 常用資料型態

MySQL 資料庫的資料欄位型態可分為文字類型、數值類型、日期時間類型,與特殊類型,下面列出常用的欄位型態:
文字型態
適用於儲存文字資料的欄位型態,其中 VARCHAR 、 CHAR 必須指定文字長度 實際儲存的資料超過設定的文字長度,雖可儲存但超過的部份將被截斷。例如儲存文字「 How are you ? 」到文字長度設定為 10 的欄位,將只剩下「 How are yo 」,若設定過度的文字長度則會佔用儲存空間,建議視實際儲存的資料需求設定文字型態。
資料型態儲存位元說明VARCHAR (M)

1~255

非 固 定 長 度 字 元 的 資 料 型 態
例 如 儲 存 通 訊 地 址 。
CHAR (M)

1~255

固 定 長 度 字 元 的 資 料 型 態
例 如 儲 存 身 份 證 字 號 。
TINYTEXT

255

適 用 於 儲 存 255 字 元 以 內 的 資 料TEXT

65535

適 用 於 儲 存 較 多 字 元 的 資 料
例 如 訪 客 留 言 板 的 內 容
MEDIUMTEXT

1677215

適 用 於 儲 存 大 容 量 文 字 的 資 料LONGTEXT

4294967295

適 用 於 儲 存 超 大 容 量 文 字 的 資 料
數值型態
適於於儲存數字資料的欄位型態,例如會員編號、商品價格、學生成績等,設定為 signed 時資料範圍可以是負值,設定為 unsigned 時資料範圍僅能儲存正值。必須注意數值型態的儲存範圍,例如商品價格若為 5000 元,儲存於 TINYINT 數值型態的欄位,查詢時將變成 127 元 ( signed ) 或 255 元 ( unsigned ),造成顯示或計算錯誤的問題,若設定較大的資料範圍則會佔用儲存空間,同樣建議視實際儲存的數值上限設定數值型態。
資料型態位元資料範圍TINYINT

1

signed: -128 ~ 127
unsigned: 0 ~ 255
SMALLINT

2

signed: -32768 ~ 32767
unsigned: 0 ~ 65535
MEDIUMINT

3

signed: -8388608 ~ 8388607
unsigned: 0 ~ 16777215
INT

4

signed: -2147483648 ~ 2147483647
unsigned: 0 ~ 4294967295
BIGINT

8

signed: -9223372036854775808 ~ 9223372036854775807
unsigned: 0 ~ 1844674407370951615
日期時間型態
資料型態儲存位元資料範圍DATE3 bytes1000-01-01 ~ 9999-12-31TIME3 bytes-838:59:59 ~ 838:59:59DATETIME8 bytes1000-01-01 00:00:00 ~ 9999-12-31 23:59:59

有關 MySQL 資料型態的詳細介紹可參考官方網站的說明:
http://dev.mysql.com/doc/refman/5.0/en/data-types.html
文章出處
http://www.cg.com.tw/php/htm/Dreamweaver_005.asp

[……]

閱讀更多

PHP substr 取得某一區段文字 字串分割

<?php

$rest = substr(“abcdef”, 0 , 1); // returns “a”
$rest = substr(“abcdef”, 2 , 2); // returns “cd”
$rest = substr(“abcdef”, -1); // returns “f”
$rest = substr(“abcdef”, -2); // returns “ef”
$rest = substr(“abcdef”, -3, 1); // returns “d”

$rest = substr(“abcdef”, 0, -1);  // returns “abcde”
$rest = substr(“abcdef”, 2, -1);  // returns “cde”
$rest = substr(“abcdef”, 4, -4);  // returns false
$rest = substr(“abcdef”, -3, -1); // returns “de”
?>

原文

http://us2.php.net/manual/en/function.substr.php[……]

閱讀更多

PHP 使用 nusoap 連接 call webservice function sample (支援utf-8)

下儎 nusoap-0.9.5
http://sourceforge.net/projects/nusoap/

include(‘nusoap-0.9.5/lib/nusoap.php’);

// 顯示錯誤
ini_set(“display_errors”, “On”);
error_reporting(E_ALL & ~E_NOTICE);

$xml = <<<XML
<?xml version=”1.0″ encoding=”utf-8″ ?>
<ORDER_DOC>
<ORDER>
<ECNO>263</ECNO>
<ODNO>00000000038</ODNO>
<STNO>F001558</STNO>
<AMT>500</AMT>
</ORDER>
<ORDERCOUNT>
<TOTALS>1</TOTALS>
</ORDERCOUNT>
</ORDER_DOC>
XML;
//<?

// 創建一個soapclient對象,參數是server的WSDL
$client = new soapclient(‘https://www.yourdomain.com/webservice/service.asmx?wsdl’, ‘wsdl’);

// 設定utf-8編碼
$client->soap_defencoding = ‘UTF-8’;
$client->decode_utf8 = false;
$client->encode_utf8 = true;

//錯誤訊息
if ($err=$client->getError()) {
  print “ERROR: $err”;
}

// 呼叫遠端函數
$result = $client->call(‘ORDERS_ADD’,array(‘xmlStr’=>$xml));

// 接收回應
if ($client->fault)
{
echo ‘<h2>Fault</h2><pre>’;
print_r($result);
echo ‘</pre>’;
}
 else
 {

// Check for errors
$err = $client->getError();
if ($err)
{
// Display the error
echo ‘<h2>Error</h2><pre>’ . $err . ‘</pre>’;
}
else
{
// Display the result
echo ‘<h2>Result</h2><pre>’;
print_r($result);
echo ‘</pre>’;
}
}

SAMPLE
https://drive.google.com/file/d/0B0WjmRBDYP2fM1FhaFNSb3hYbUE/edit?usp=sharing

[……]

閱讀更多

php array to query string

<?php
$data 
= array(‘foo’‘bar’‘baz’‘boom’‘cow’ => ‘milk’‘php’ =>‘hypertext processor’);

echo http_build_query($data) . “n”;
echo 
http_build_query($data‘myvar_’);?>
output

0=foo&1=bar&2=baz&3=boom&cow=milk&php=hypertext+processor
myvar_0=foo&myvar_1=bar&myvar_2=baz&myvar_3=boom&cow=milk&php=hypertext+processor

原文
http://www.php.net/manual/en/function.http-build-query.php

[……]

閱讀更多

PHP 5.1.x 不支援 json_encode 使用 php function 的解決方案

PHP 5.2 才有支源 json_encode()
5.2以下會顯示下列錯誤
PHP Fatal error:  Call to undefined function json_encode()
可在PHP中加入下列function即可使用json_encode()
語法主要先檢查是否有json_encode這個function
如果沒有(php無支援)就使用下列function產生json格式字串

//PHP 5.1.x 不支援 json_encode()
if ( !function_exists(‘json_encode’) ){
function json_encode($data)
{
    if( is_array($data) || is_object($data) ) {
        $islist = is_array($data) && ( empty($data) || array_keys($data) === range(0,count($data)-1) );

        if( $islist ) {
            $json = ‘[‘ . implode(‘,’, array_map(‘json_encode’, $data) ) . ‘]’;
        } else {
            $items = Array();
            foreach( $data as $key => $value ) {
                $items[] = json_encode(“$key”) . ‘:’ . json_encode($value);
            }
            $json = ‘{‘ . implode(‘,’, $items) . ‘}’;
        }
    } elseif( is_string($data) ) {
        # Escape non-printable or Non-ASCII characters.
        # I also put the \ character first, as suggested in comments on the ‘addclashes’ page.
        $string = ‘”‘ . addcslashes($data, “\”nrt/” . chr(8) . chr(12)) . ‘”‘;
        $json    = ”;
        $len    = strlen($string);
        # Convert UTF-8 to Hexadecimal Codepoints.
        for( $i = 0; $i < $len; $i++ ) {

            $char = $string[$i];
            $c1 = ord($char);

            # Single byte;
            if( $c1 <128 ) {
                $json .= ($c1 > 31) ? $char : sprintf(“\u%04x”, $c1);
                continue;
            }

            # Double byte
            $c2 = ord($string[++$i]);
            if ( ($c1 & 32) === 0 ) {
                $json .= sprintf(“\u%04x”, ($c1 – 192) * 64 + $c2 – 128);
                continue;
            }

            # Triple
            $c3 = ord($string[++$i]);
            if( ($c1 & 16) === 0 ) {
                $json .= sprintf(“\u%04x”, (($c1 – 224) <<12) + (($c2 – 128) << 6) + ($c3 – 128));
                continue;
            }

            # Quadruple
            $c4 = ord($string[++$i]);
            if( ($c1 & 8 ) === 0 ) {
                $u = (($c1 & 15) << 2) + (($c2>>4) & 3) – 1;

                $w1 = (54<<10) + ($u<<6) + (($c2 & 15) << 2) + (($c3>>4) & 3);
                $w2 = (55<<10) + (($c3 & 15)<<6) + ($c4-128);
                $json .= sprintf(“\u%04x\u%04x”, $w1, $w2);
            }
        }
    } else {
        # int, floats, bools, null
        $json = strtolower(var_export( $data, true ));
    }
    return $json;
}
}[……]

閱讀更多