常用語法

一次存取 N 筆資料
select * from table1 where 1=1 LIMIT N

insert into testTable (PrimeID,NDSID,NDSIDHex,ChipID) values('LAHJD081601133','9006EF02760160470','AAA','AAA');

delete from testtable where PrimeID = 'LAHJD081601133';

create table testtable (PrimeID char(15) not null, NDSID char(17) not null,NDSIDHex char(10) not null,ChipID char(10) not null,primary key(PrimeID));
更新root密碼
use mysql;
UPDATE user SET password=password(’newpassword’)
WHERE user = ‘root’;
FLUSH PRIVILEGES; #為立即更新\r

相關網站

SQL語法教學

大小寫問題
在 MySQL 中,資料庫和資料表就相對於目錄下的目錄和文件,因而,操作系统的敏感性决定数据库和表命名的大小写敏感。这就意味着数据库和表名在 Windows 中是大小写不敏感的,而在大多数类型的 Unix 系统中是大小写敏感的。

奇怪的是列名与列的别名在所有的情况下均是忽略大小写的,而表的别名又是区分大小写的。

要避免这个问题,你最好在定义数据库命名规则的时候就全部采用小写字母加下划线的组合,而不使用任何的大写字母。

或 者也可以强制以 -O lower_case_table_names=1 参数启动 mysqld(如果使用 --defaults-file=...\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一行 lower_case_table_names=1)。这样MySQL 将在创建与查找时将所有的表名自动转换为小写字符(这个选项缺省地在 Windows 中为 1 ,在 Unix 中为 0。从 MySQL 4.0.2 开始,这个选项同样适用于数据库名)。

当你更改这个选项时,你必须在启动 mysqld 前首先将老的表名转换为小写字母。

换 句话说,如果你希望在数据库里面创建表的时候保留大小写字符状态,则应该把这个参数置0: lower_case_table_names=1 。否则的话你会发现同样的sqldump脚本在不同的操作系统下最终导入的结果不一样(在Windows下所有的大写字符都变成小写了)。

MySQL簡易備份方法

要備份 MySQL 資料庫主要分為兩個方法,
一是將資料庫目錄完整備份
二是使用 MySQL 內建的 mysqldump 程式。
備份資料庫目錄
MySQL 預設的儲存目錄在 /var/lib/mysql 內容,底下會有以資料庫名稱的目錄,例如 mydb 目錄便應該是 mydb 資料庫的資料。

如果 MySQL 正在運行,請先停止 MySQL,原因是可能會有資料未完全寫入,而 MySQL 會 lock 在使用中的 DB 檔案。

01 /etc/rc.d/init.d/mysqld stop
02 cd /var/lib/mysql/
03 tar zxcf mydb_backup.tgz mydb
04 /etc/rc.d/init.d/mysqld start


以上指令會先停止 MySQL,然後把 mydb 資料庫製作一個 taz 檔的備份,並儲存到 mydb_backup.tgz。
在使用以上指令時,請根據個別系統的設定作出修改。

好了,以上就麼 3 句指令就完成備份了,如果不幸的事情發生了,資料庫發生錯誤而要復原資料,可使用以下指令:

01 /etc/rc.d/init.d/mysqld stop
02 cd /var/lib/mysql/
03 mv mydb mydb_error
04 tar zxvf mydb_backup.tgz
05 /etc/rc.d/init.d/mysqld start


以上指令是先把 /var/lib/mysql/mydb 移到 /var/lib/mysql/mydb_error,然後將原先製作的備份檔解壓到 /var/lib/mysql/mydb。

mysqldump
雖然以上方法十分簡單,但有一個問題存在,那就是在備份及復原時均需停止 MySQL 的運作,這樣對於實際應用十分不便。再者,這樣備份出來的檔案,如果在相同版本的 MySQL Server 應該沒有問題,但移到版本不同的 Server 則不一定可以成功復原。

因為有以上的問題,MySQL 已經內建了備份工具,它就是 mysqldump。
mysqldump 的備份方法是將資料庫內的每個資料表結構及每筆資料產生 SQL 語句,然後存到文字檔。而且它可以自訂每一個資料表一個檔案,以及將資料表結構及資料分開儲存,以下是使用例子:

01 mysqldump --user=root -p mydb > /backup/mydb.sql


以上指令會使用 mysqldump 將 mydb 備份到 /backup/mydb.sql,在輸入指令後,需要輸入 MySQL 的 root 密碼。

至於復原資料同樣簡單,只要一句指令便完成:

01 mysqldump --user=root -p mydb < /backup/mydb.sql


以上指令會將 /backup/mydb.sql 備份檔復原到 mydb 裡面。如果你的 MySQL Server 不止一個資料庫,希望可以一次過將所有資料庫備份起來,可以寫一個簡單的 shell script 完成,又或者使用以下指令:

01 mysqldump --user=root -p --all-databases > /backup/mysql.sql


這個 --all-databases 代表所有資料庫,這樣 mysqldump 便會將所有資料庫備份到 /backup/mysql.sql。


====================================================
歡迎轉載,但轉載時請保留此宣告,不得作為商業用途
作者: Sam Tang
來源網站: http://www.phpdc.com/

最簡便的備份MySql資料庫方法 -- mysqldump
最簡便的備份MySql資料庫方法
作者:技術天地 發文時間:2005.08.04


使用MYSQL進行資料庫備份,有很正規的資料庫備份方法,同其他的資料庫伺服器有相同的概念,但有沒有想過,MySQL會有更簡捷的使用檔目錄的備份方法,而且又快有好。

一、資料備份捷徑

因為這個方法沒有得到官方正式文檔的驗證,我們暫稱為試驗吧。

目的:備份hostA主機中一個mysql資料庫TestA,並恢復到到hostB機中

試驗環境:

作業系統:WinNT4.0,Mysql3.22.34,phpMyAdmin 2.1.0

在hostA中安裝mysql資料庫並建立TestA資料庫

hostB機安裝mysql資料庫,沒有TestA資料庫

方法步驟:

啟動phpMyAdmin察看HostA和HostB中的資料庫列表,在HostB中沒有TestA資料庫

找到HostA中mysql的安裝目錄,並找到資料庫目錄data

在我的試驗環境中,這個目錄是

C:\mysql\data

找到對應資料庫名稱的子目錄

C:\mysql\data\TestA

粘貼拷貝到HostB的Data目錄下,是HostA同HostB Mysql資料目錄下的檔相同

刷新HostB的phpMyAdmin察看一下資料庫列表,我們看到TestA已經出現,並且作查詢修改等操作都正常,備份恢復恢復成功

試驗結論:Mysql的資料庫可以通過檔形式保存,備份,恢復只要將相應檔目錄恢復即可,無需使用其他工具備份。

二、正規的方法(官方建議):

導出要用到MySQL的mysqldump工具,基本用法是:

代碼:

mysqldump [OPTIONS] database [tables]



如果你不給定任何表,整個資料庫將被導出。

通過執行mysqldump --help,你能得到你mysqldump的版本支援的選項表。

注意,如果你運行mysqldump沒有--quick或--opt選項,mysqldump將在導出結果前裝載整個結果集到記憶體中,如果你正在導出一個大的資料庫,這將可能是一個問題。

mysqldump支援下列選項:

--add-locks

在每個表導出之前增加LOCK TABLES並且之後UNLOCK TABLE。(為了使得更快地插入到MySQL)。

--add-drop-table

在每個create語句之前增加一個drop table。

--allow-keywords

允許創建是關鍵字的列名字。這由在列名前面加表名的方法做到。

-c, --complete-insert

使用完整的insert語句(用列名字)。

-C, --compress

如果客戶和伺服器均支援壓縮,壓縮兩者間所有的資訊。

--delayed

用INSERT DELAYED命令插入行。

-e, --extended-insert

使用全新多行INSERT語法。(給出更緊縮並且更快的插入語句)

-#, --debug[=option_string]

跟蹤程式的使用(為了調試)。

--help

顯示一條幫助消息並且退出。

--fields-terminated-by=...

--fields-enclosed-by=...

--fields-optionally-enclosed-by=...

--fields-escaped-by=...

--fields-terminated-by=...

這些選擇與-T選擇一起使用,並且有相應的LOAD DATA INFILE子句相同的含義。

LOAD DATA INFILE語法。

-F, --flush-logs

在開始導出前,洗掉在MySQL伺服器中的日誌檔。

-f, --force,

即使我們在一個表導出期間得到一個SQL錯誤,繼續。

-h, --host=..

從命名的主機上的MySQL伺服器導出資料。缺省主機是localhost。

-l, --lock-tables.

為開始導出鎖定所有表。

-t, --no-create-info

不寫入表創建資訊(CREATE TABLE語句)

-d, --no-data

不寫入表的任何行資訊。如果你只想得到一個表的結構的導出,這是很有用的!

--opt

同--quick --add-drop-table --add-locks --extended-insert --lock-tables。

應該給你為讀入一個MySQL伺服器的盡可能最快的導出。

-pyour_pass, --password[=your_pass]

與伺服器連接時使用的口令。如果你不指定“=your_pass”部分,mysqldump需要來自終端的口令。

-P port_num, --port=port_num

與一台主機連接時使用的TCP/IP埠號。(這用於連接到localhost以外的主機,因為它使用 Unix套接字。)

-q, --quick

不緩衝查詢,直接導出至stdout;使用mysql_use_result()做它。

-S /path/to/socket, --socket=/path/to/socket

與localhost連接時(它是缺省主機)使用的套接字檔。

-T, --tab=path-to-some-directory

對 於每個給定的表,創建一個table_name.sql檔,它包含SQL CREATE 命令,和一個table_name.txt檔,它包含資料。注意:這只有在mysqldump運行在mysqld守護進程運行的同一台機器上的時候才工 作。.txt檔的格式根據--fields-xxx和-- lines--xxx選項來定。

-u user_name, --user=user_name

與伺服器連接時,MySQL使用的用戶名。缺省值是你的Unix登錄名。

-O var=option, --set-variable var=option

設置一個變數的值。可能的變數被列在下面。

-v, --verbose

冗長模式。列印出程式所做的更多的資訊。

-V, --version

列印版本資訊並且退出。

-w, --where='where-condition'

只導出被選擇了的記錄;注意引號是強制的!

"--where=user='jimf'" "-wuserid>1" "-wuserid<1"


最常見的mysqldump使用可能製作整個資料庫的一個備份:
代碼:
mysqldump -p --opt database > backup-file.sql

但是它對用來自於一個資料庫的資訊充實另外一個MySQL資料庫也是有用的:

代碼:

mysqldump --opt database | mysql --host=remote-host -C database

由於mysqldump導出的是完整的SQL語句,所以用mysql客戶程式很容易就能把資料導入了:

代碼:
mysqladmin create target_db_name
mysql target_db_name < backup-file.sql[code]如果使用 mysqldump 製作資料表的備份...而且不寫入表創建資訊(CREATE TABLE語句)...可以利用參數 -t:
代碼:
mysqldump -p -t database tables > backup-tables.sql

如果要還原資料表
mysql database -p < backup-tables.sql[/code]文件取自:
[url]http://forum.icst.org.tw/phpBB2/viewtopic.php?t=8362&[/url]

arrow
arrow
    全站熱搜

    lver76 發表在 痞客邦 留言(0) 人氣()