前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >《深入浅出SQL》问答录(四)

《深入浅出SQL》问答录(四)

作者头像
看、未来
发布2020-08-25 17:01:40
4530
发布2020-08-25 17:01:40
举报
在这里插入图片描述
在这里插入图片描述

本系列出自《深入浅出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使用示例

代码语言:javascript
复制
ALTER TABLE my_contacts
ADD COLUMN contact_id INT NOT NULL AUTO_INCREMENT FIRST,
ADD PRIMARY KEY(contact_id);
代码语言:javascript
复制
ALTER TABLE my_contacts 
ADD COLUMN phone VARCHAR(10)
AFTER list_name;
代码语言:javascript
复制
CHANGE --可同时改变现有列的名称和数据类型
MODIFY --修改现有列的数据类型或数据
ADD    --在当前表中添加一列,可自选类型
DROP   --从当前表中删除某列
代码语言:javascript
复制
ALTER TABLE project_list
CHANGE COLUMN number proj_id INT NOT NULL AUTO_INCREMENT,
ADD PRIMARY KEY(proj_id);
--将原名为“name”的列的名称和类型修改
--如果把数据改成另一种类型,你可能会丢失数据
代码语言:javascript
复制
ALTER TABLE project_list
CHANGE COLUMN descriptionofproj proj_desc VARCHAR(10),
CHANGE COLUMN contractoronjob con_name VARCHAR(30),
代码语言:javascript
复制
ALTER TABLE project_list
MODIFY COLUMN proj_desc VARCHAR(120);
代码语言:javascript
复制
ALTER TABLE project_list
DROP COLUMN start_date;

一些便利的字符串函数

代码语言:javascript
复制
SELECT RIGHT(lie,2) FROM my_contacts;	--从lie列中读取两个字符
代码语言:javascript
复制
SELECT SUBSTRING_INDEX(lie,',',1) FROM my_contacts;
--截取部分字符串,第三个参数就是寻找第一个逗号,用于截取第一个逗号之前的所有字符。
代码语言:javascript
复制
SELECT UPPER('usa');	--把整整组字符串改大写
SELECT LOWER('USA');	--改小写
代码语言:javascript
复制
SELECT LTRIM(' dogfood ');	--清除左侧空格
SELECT RTRIM(' catfood ');
代码语言:javascript
复制
SELECT LENGTH('San Antonio,TX'); --返回字符串中的字符数量
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-07-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问答录
  • 花絮
    • ALTER使用示例
      • 一些便利的字符串函数
      相关产品与服务
      云数据库 MySQL
      腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档