扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
建表时指定主键:
站在用户的角度思考问题,与客户深入沟通,找到嵊泗网站设计与嵊泗网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站设计、成都做网站、企业官网、英文网站、手机端网站、网站推广、域名与空间、虚拟主机、企业邮箱。业务覆盖嵊泗地区。
CONSTRAINT pk_name PRIMARY KEY(列名);
建表时指定外键:
CONSTRAION pk_name FOREIGN KEY(列名) REFERENCES table_name(列名);
可以直接自己添加描述字段。
DROP TABLE IF EXISTS `user`;
CREATE TABLE user
( idBIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT
COMMENT '主键',
username VARCHAR(50) NOT NULL DEFAULT ''
COMMENT '用户名',
username_type VARCHAR(20) NOT NULL DEFAULT ''
COMMENT '用户类型',
user_password VARCHAR(50) NOT NULL DEFAULT ''
COMMENT '用户密码',
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
COMMENT '创建时间',
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE
CURRENT_TIMESTAMP
COMMENT '更新时间',
PRIMARY KEY (id),
UNIQUE KEY idx_urn(username) USING BTREE
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8mb4
COMMENT = '用户信息表';
或者。
#创建表的时候写注释
CREATE TABLE userinfo(
id INT COMMENT '编号',
uname VARCHAR(40) COMMENT '用户名',
address VARCHAR(120) COMMENT '家庭住址',
hobby VARCHAR(200) COMMENT '爱好'
)COMMENT = '用户信息表';
#修改表的注释
ALTER TABLE userinfo COMMENT '用户信息资料表';
#修改字段的注释,注意:字段名和字段类型照写就行
ALTER TABLE userinfo MODIFY COLUMN uname VARCHAR(40) COMMENT '姓名';
#查看表注释的方法,在生成的SQL语句中看
SHOW CREATE TABLE userinfo;
#在元数据的表里面看
USE information_schema;
SELECT * FROM TABLES WHERE TABLE_SCHEMA='shoppingcart' AND TABLE_NAME='userinfo';
#查看字段注释的方法
SHOW FULL COLUMNS FROM userinfo;
#在元数据的表里面看
SELECT * FROM COLUMNS WHERE TABLE_SCHEMA='shoppingcart' AND TABLE_NAME='userinfo';
扩展资料:
mysql查询和索引:
只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值。如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快--不管有没有使用索引。
只有当数据库里的记录超过了 1000 条、数据总量也超过了 MySQL 服务器上的内存总量时,数据库的性能测试结果才有意义。
在不确定应该在哪些数据列上创建索引的时候,人们从 EXPLAIN SELECT 命令那里往往可以获得一些帮助。这其实只是简单地给一条普通的 SELECT 命令加一个 EXPLAIN 关键字作为前缀而已。
有了这个关键字,MySQL 将不是去执行那条 SELECT 命令,而是去对它进行分析。MySQL 将以表格的形式把查询的执行过程和用到的索引等信息列出来。
在 EXPLAIN 命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的先后顺序排列。type列指定了本数据表与其它数据表之间的关联关系(JOIN)。在各种类型的关联关系当中。
效率最高的是 system,然后依次是 const、eq_ref、ref、range、index 和 All(All 的意思是:对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍——这种情况往往可以用一索引来避免)。
possible_keys 数据列给出了 MySQL 在搜索数据记录时可选用的各个索引。key 数据列是 MySQL 实际选用的索引,这个索引按字节计算的长度在 key_len 数据列里给出。
比如说,对于一个 INTEGER 数据列的索引,这个字节长度将是4。如果用到了复合索引,在 key_len 数据列里还可以看到 MySQL 具体使用了它的哪些部分。作为一般规律,key_len 数据列里的值越小越好。
ref 数据列给出了关联关系中另一个数据表里的数据列的名字。row 数据列是 MySQL 在执行这个查询时预计会从这个数据表里读出的数据行的个数。row 数据列里的所有数字的乘积可以大致了解这个查询需要处理多少组合。
最后,extra 数据列提供了与 JOIN 操作有关的更多信息,比如说,如果 MySQL 在执行这个查询时必须创建一个临时数据表,就会在 extra 列看到 usingtemporary 字样。
参考资料来源:百度百科-MySQL
应该可以直接在create语句中加上注释呀,比如MySQL的
CREATE TABLE `oa_apps` (
`app_seq_id` int(10) unsigned NOT NULL auto_increment COMMENT '自动编号',
`name` varchar(20) default NULL COMMENT '名称',
`father_seq_id` int(10) unsigned default NULL COMMENT '栏目ID',
`bg` varchar(100) default NULL COMMENT '背景图片',
`width` int(11) default NULL COMMENT '宽度',
`height` int(11) default NULL COMMENT '高度',
`page_url` varchar(200) default NULL COMMENT '外部页面',
`place_seq` int(10) unsigned default NULL COMMENT '排序序号',
`link` tinyint(1) default '0' COMMENT '新窗口链接',
PRIMARY KEY (`app_seq_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='应用中心' AUTO_INCREMENT=1 ;
在字段后面添加comment 'XXX'
例如:
CREATE TABLE `XXX` (
`ID` int NOT NULL COMMENT '应用ID',
)
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流