创建表

简单的方式

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;


创建临时表

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;

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

查询表中不重复的数据,使用distinct:

例如选取表中所有的数据

select distinct *from table_name

最新文章

  1. 详解前端模块化工具-webpack
  2. 理解 Neutorn LBaaS - 每天5分钟玩转 OpenStack(120)
  3. 用vue.js学习es6(六):Iterator和for...of循环
  4. Spring MVC 学习总结(三)——请求处理方法Action详解
  5. SELECT (Transact-SQL)
  6. 12.享元模式(Flyweight Pattern)
  7. Squid 操作实践
  8. WooCommerce微信支付插件免费版下载
  9. DOS命令 Net config server Net config workstation
  10. Vivado学习笔记_002
  11. MVC4
  12. WPF中获取系统本身自带的控件模板(XAML)
  13. freemarker之include指令
  14. avcodec_decode_video2()解码视频后丢帧的问题解决
  15. 销售订单-修改量-高级定价关联sql
  16. DSAPI 网页获取本地程序登陆用户
  17. 命令 上传项目到git中
  18. Mac下Homebrew的安装与使用
  19. GitHub 翻译之 'Hello-world' 翻译
  20. android openCL的so库目录(转)

热门文章

  1. 【BZOJ 3669】 [Noi2014]魔法森林 LCT维护动态最小生成树
  2. Codeforces 937.C Save Energy!
  3. POJ1062:昂贵的聘礼(dfs)
  4. php魔术方法的使用
  5. 【数据结构】bzoj2957楼房重建
  6. 使用FindBugs-IDEA插件找到代码中潜在的问题
  7. 【LA4670-Dominating Patterns】AC自动机
  8. Codeforces Round #300 解题报告
  9. NGINX : 如何屏蔽未被定义的虚拟主机的访问
  10. Mysql添加视图