1. 程式人生 > >MySql 的一些常用操作語句

MySql 的一些常用操作語句

//建立student表和class表相關聯的檢視
create view student_class_view as select * from student, class where student.scid = class.cid;
//建立student表, scid欄位是外來鍵,關聯到class表的主鍵
CREATE TABLE student(sid INT PRIMARY KEY NOT NULL AUTO_INCREMENT, scid INT , FOREIGN KEY(scid) REFERENCES class(cid)) ENGINE=INNODB;
//建立class表
CREATE TABLE class(cid INT PRIMARY KEY NOT NULL AUTO_INCREMENT, t1id INT not null, score INT);
//從檢視中查詢資料,檢視可以吧多個表的資料通過一定的關係對映到一起,操作起來和你方便,避免了大量的sql語句
select * from student_class_view;
//刪除表 (刪除表資料用 delete)
drop table class;

//建立索引,對於頻繁操作的欄位最好建立一個索引哦,檢索效率上會大大的提高,至於原理,百度一下你就知道。
create index idx_class_score on class(score);
//資料插入操作測試
insert into class values(default, 2, 99);
insert into student (sid, scid) values(default, 3);
SELECT * FROM student_class_view;
//以上語句全部測試通過...
------------------------------------------------------------------------------------分割線-------------------------------------------------------------------------------------

建立表

簡單的方式

CREATE TABLE person (
number INT(11),
name VARCHAR(255),
birthday DATE
);

或者是

CREATE TABLE IF NOT EXISTS person (
number INT(
11), name VARCHAR(255), birthday DATE );

檢視mysql建立表:

複製程式碼
SHOW CREATE table person;

CREATE TABLE `person` (
  `number` int(11) DEFAULT NULL,
  `name` varchar(255) DEFAULT NULL,
  `birthday` date DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
複製程式碼

查看錶所有的列:

複製程式碼
SHOW FULL COLUMNS from person;
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| Field    | Type         | Collation       | Null | Key | Default | Extra | Privileges                      | Comment |
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
| number   | int(11)      | NULL            | YES  |     | NULL    |       | select,insert,update,references |         |
| name     | varchar(255) | utf8_general_ci | YES  |     | NULL    |       | select,insert,update,references |         |
| birthday | date         | NULL            | YES  |     | NULL    |       | select,insert,update,references |         |
+----------+--------------+-----------------+------+-----+---------+-------+---------------------------------+---------+
複製程式碼

建立臨時表

CREATE TEMPORARY TABLE temp_person (
number INT(11),
name VARCHAR(255),
birthday DATE
);

在建立表格時,您可以使用TEMPORARY關鍵詞。只有在當前連線情況下,TEMPORARY表才是可見的。當連線關閉時,TEMPORARY表被自動取消。這意味著兩個不同的連線可以使用相同的臨時表名稱,同時兩個臨時表不會互相沖突,也不與原有的同名的非臨時表衝突。(原有的表被隱藏,直到臨時表被取消時為止。)您必須擁有CREATE TEMPORARY TABLES許可權,才能建立臨時表。

如果表已存在,則使用關鍵詞IF NOT EXISTS可以防止發生錯誤。

CREATE TABLE IF NOT EXISTS person2 (
number INT(11),
name VARCHAR(255),
birthday DATE
);

注意,原有表的結構與CREATE TABLE語句中表示的表的結構是否相同,這一點沒有驗證。註釋:如果您在CREATE TABLE...SELECT語句中使用IF NOT EXISTS,則不論表是否已存在,由SELECT部分選擇的記錄都會被插入。

CREATE TABLE語句的末尾新增一個SELECT語句,在一個表的基礎上建立表

CREATE TABLE new_tbl SELECT * FROM orig_tbl;

注意,用SELECT語句建立的列附在表的右側,而不是覆蓋在表上

複製程式碼
mysql> SELECT * FROM foo;
+---+
| n |
+---+
| 1 |
+---+
mysql> CREATE TABLE bar (m INT) SELECT n FROM foo;
mysql> SELECT * FROM bar;
+------+---+
| m    | n |
+------+---+
| NULL | 1 |
+------+---+
複製程式碼

也可以明確地為一個已生成的列指定型別

CREATE TABLE foo (a TINYINT NOT NULL) SELECT b+1 AS a FROM bar;

根據其它表的定義(包括在原表中定義的所有的列屬性和索引),使用LIKE建立一個空表:

CREATE TABLE new_tbl LIKE orig_tbl;

建立一個有主鍵,唯一索引,普通索引的表:

複製程式碼
CREATE TABLE `people` (
  `peopleid` smallint(6) NOT NULL AUTO_INCREMENT,
  `firstname` char(50) NOT NULL,
  `lastname` char(50) NOT NULL,
  `age` smallint(6) NOT NULL,
  `townid` smallint(6) NOT NULL,
  PRIMARY KEY (`peopleid`),
  UNIQUE KEY `unique_fname_lname`(`firstname`,`lastname`),
  KEY `fname_lname_age` (`firstname`,`lastname`,`age`)
) ;
複製程式碼

其中peopleid是主鍵,以firstname和lastname兩列建立了一個唯一索引,以firstname,lastname,age三列建立了一個普通索引

刪除表

DROP TABLE  tbl_name;

或者是

DROP TABLE IF EXISTS tbl_name;