MySql 的一些常用操作语句

发布时间:2014-10-23 23:26:13
来源:分享查询网

//创建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;      

返回顶部
查看电脑版