删除语句
delete from 表名 where 条件
limit
选择数据几条。 就 limit + 条数。
删除表内所有数据行外 还要实现对表结构中自增列的重置,只需一行代码搞定: truncate + 表名
UNIQUE
UNIQUE 约束唯一标识数据库表中的每条记录。
创建新表时的字符集设置
CHARACTER set utf8 collate utf8_general_ci
DEFAULT CHARACTER SET utf8:数据库字符集。设置数据库的默认编码为utf8,utf8中间不要"-";
COLLATE utf8_general_ci:数据库校对规则。ci是case insensitive的缩写,意思是大小写不敏感;相对的是cs,即case sensitive,大小写敏感;还有一种是utf8_bin,是将字符串中的每一个字符用二进制数据存储,区分大小写。
修改表中列的信息
altertable表名 `modify
`修改列名称 数据类型 默认值等;
altertableuser_info change 原列名 修改列名 修改数据类型;
altertable增加的表格 add` `增加列的名称 数据类型 位置(
afterlevel在`level
`之后);
索引
索引创建、删除与使用:
-
1.1 create方式创建索引:
CREATE [UNIQUE -- 唯一索引 | FULLTEXT -- 全文索引 ] INDEX index_name ON table_name -- 不指定唯一或全文时默认普通索引 (column1[(length) [DESC|ASC]] [,column2,...]) -- 可以对多列建立组合索引
-
1.2 alter方式创建索引:
ALTER TABLE tb_name ADD [UNIQUE | FULLTEXT] [INDEX] index_content(content)
-
2.1 drop方式删除索引:
DROP INDEX <索引名> ON <表名>
-
2.2 alter方式删除索引:
ALTER TABLE <表名> DROP INDEX <索引名>
-
3.1 索引的使用:
-
索引使用时满足最左前缀匹配原则,即对于组合索引(col1, col2),在不考虑引擎优化时,条件必须是col1在前col2在后,或者只使用col1,索引才会生效;
-
索引不包含有NULL值的列
-
一个查询只使用一次索引,where中如果使用了索引,order by就不会使用
-
like做字段比较时只有前缀确定时才会使用索引
-
在列上进行运算后不会使用索引,如year(start_time)<2020不会使用start_time上的索引
-
查询条件语句if
if(条件,满足条件结果1,不满足条件结果2)
date_format()
date_format(time,'%y%m')
通过这个函数匹配'%Y%m'年份和月份;