《深入浅出SQL》问答录(四)
时间:2022-07-23
本文章向大家介绍《深入浅出SQL》问答录(四),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本系列出自《深入浅出MySQL》,全文以问答形式展开,是我的个人学习笔记。
问答录
先看花絮
Q:如果我想改变列的顺序呢?像
ALTER TABLE MODIFY COLUMN proj_desc AFTER con_name;
这样做可以吗?A:创建表后你就无法真正的改变列的顺序了。最多只能在指定位置添加新列,然后删除旧列,但是这样会失去旧列中的所有数据。
Q:如果我已经创建了主键,然后又意外的想改用另一列呢?可以只移除主键的设置而不改变其中的数据吗?
A:可以,而且很简单。
ALTER TABLE your_table DROP PRIMARY KEY,ADD PRIMARY KEY(XXX);
Q:AUTO_INCREMENT又该如何处理/
A:你可以把它添加到没有自动递增功能的列中,如下所示:
ALTER TABLE your_table CHANGE yoour_id your_id INT(11) NOT NIULL AUTO_INCREMENT;
而且可以这样就将它删除:ALTER TABLE your_table CHANGE your_id your_id INT(11) NOT NULL;
有一点要记住:每个表中只有一列可以加上AUTO_INCREMENT,该列必须为整形而且不能包含NULL。
花絮
ALTER使用示例
ALTER TABLE my_contacts
ADD COLUMN contact_id INT NOT NULL AUTO_INCREMENT FIRST,
ADD PRIMARY KEY(contact_id);
ALTER TABLE my_contacts
ADD COLUMN phone VARCHAR(10)
AFTER list_name;
CHANGE --可同时改变现有列的名称和数据类型
MODIFY --修改现有列的数据类型或数据
ADD --在当前表中添加一列,可自选类型
DROP --从当前表中删除某列
ALTER TABLE project_list
CHANGE COLUMN number proj_id INT NOT NULL AUTO_INCREMENT,
ADD PRIMARY KEY(proj_id);
--将原名为“name”的列的名称和类型修改
--如果把数据改成另一种类型,你可能会丢失数据
ALTER TABLE project_list
CHANGE COLUMN descriptionofproj proj_desc VARCHAR(10),
CHANGE COLUMN contractoronjob con_name VARCHAR(30),
ALTER TABLE project_list
MODIFY COLUMN proj_desc VARCHAR(120);
ALTER TABLE project_list
DROP COLUMN start_date;
一些便利的字符串函数
SELECT RIGHT(lie,2) FROM my_contacts; --从lie列中读取两个字符
SELECT SUBSTRING_INDEX(lie,',',1) FROM my_contacts;
--截取部分字符串,第三个参数就是寻找第一个逗号,用于截取第一个逗号之前的所有字符。
SELECT UPPER('usa'); --把整整组字符串改大写
SELECT LOWER('USA'); --改小写
SELECT LTRIM(' dogfood '); --清除左侧空格
SELECT RTRIM(' catfood ');
SELECT LENGTH('San Antonio,TX'); --返回字符串中的字符数量
- Golang语言社区--Go语言基础第四节类型
- Golang语言社区--go语言编写Web程序
- Golang语言社区--Go语言基础第五节流程控制
- (14)不同基因坐标转换-生信菜鸟团博客2周年精选文章集
- (15)基因组各种版本对应关系-生信菜鸟团博客2周年精选文章集
- go 并发处理脚本
- 生信菜鸟团博客2周年精选文章集(4)NCBI数据库的几个探索
- PHP 的前世今生
- 【直播】我的基因组49:Y染色体的SNV不能用常规流程来找?
- 【直播】我的基因组46:SNV突变(96种)频谱的制作
- 深入剖析-Oracle索引分支块的结构
- 【直播】我的基因组48:我可能测了一个假的全基因组
- 【直播】我的基因组47:测序深度和GC含量的关系
- 【直播】我的基因组47:测序深度和GC含量的关系
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法