用 一、新建表 新建学生表(student): create table student ( id int not null, name varchar2(50), sex varchar2...--> 给表添加主键、外键: <!...constraint pk_name; 6.修改表字段类型 例子:alter table student alter column birthday decimal(18, 4) not null 三、简单的sql...-- 只清空表中数据,但是保留表 --> (4)删除表: 语法:DROP TABLE 表名称 例子:drop table Student <!...= 'lisi',sex='男' where id=1 4.查询 (1)查询表中所有数据 语法: select * from 表名 例子: select * from Student (2)查询表中满足某条件的数据
1、点击[testdb] 2、点击[表] 3、点击[新建] 4、点击[表] 5、点击[列名] 6、点击[数据类型] 7、点击[nchar(10)] 8、点击[int] 9、点击[允许Null...、点击[列名] 13、点击[数据类型] 14、点击[允许Null值] 15、点击[列名] 16、点击[数据类型] 17、点击[nchar(10)] 18、点击[int] 19、点击[文件...] 20、点击[保存] 21、点击[输入表名称] 22、点击[确定] 23、点击[表] 24、点击[dbo.userinfo] 25、点击[设计] 26、点击[列名] 27、点击[
大家好,又见面了,我是全栈君 因为项目需要,最近研究了一下在mysql数据库下如何动态新建以及删除分区表。如果全部借助存储过程的话,新建以及删除分区表在逻辑上比较死板、不灵活,而且还容易出错。...因此,我新建了一个数据表table_fen_qu,借助这个表可以很(相对)灵活的对分区表进行管理。...建立新建分区表的存储过程代码如下: drop procedure if exists general_procedure; -- general_procedure的作用:新建分区表及在table_fen_qu...表中存储新建分区表时的相关参数 -- general_procedure的参数:表名,分区表之间的时间间隔(单位为小时),要新增的分区表个数 create procedure general_procedure...set minMonitTimeStr = CONCAT('p',DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s")); -- 拼接添加分区表sql
SQL Join 中,表位置对性能的影响 出这样一个话题,老读者估计要说我炒冷饭。 其实还真不是。两表的 Join, Internals(内幕)还是有很多可以讨论。...而反过来,将订单表作为 Outer Input, 则需要把整张订单表做 Scan/Seek, 那么量级就相差很远。...由此可以推测,优化器选择执行计划时,一定程度上自动判断了两表大小,选择小表在前,大表在后的原则。小表驱动大表查询,是优化时着重考虑的策略。
图 | 榖依米 SQL Join 中,表位置对性能的影响 出这样一个话题,老读者估计要说我炒冷饭。 其实还真不是。两表的 Join, Internals(内幕)还是有很多可以讨论。...而反过来,将订单表作为 Outer Input, 则需要把整张订单表做 Scan/Seek, 那么量级就相差很远。...由此可以推测,优化器选择执行计划时,一定程度上自动判断了两表大小,选择小表在前,大表在后的原则。小表驱动大表查询,是优化时着重考虑的策略。
//e = objPHPExcel->getActiveSheet()->getCell(“E”. sql = “INSERT INTO paee_course VALUES(‘”.a.”‘,'”.b....”‘)”;//,”.c.”,”.d.”,”.e.” echo sql.”j”; mysql_query($sql); /*if(!...mysql_query($sql)) { re_result(“导入数据失败,请稍后再试或与管理员联系”); }*/ } 问题: 1、在页面的输出是全部都输出成功了,但是导入数据库的时候只导入了67...至少需要这样 mysql_query($sql) or die(mysql_error()); 以便观察到出了什么问题 你在读取数据后,未作任何处理就向数据库插入 那么如果数据中含有特殊字符“’”时,不就要出错了吗...——解决方案——————– 这是因为你的表中数据太多了 你的主键是有符号的长整形(int)改成无符号的 Unsigned int 可使容量增加一倍 2147483647 是 2 的31 次方 – 1 也就是有符号长整形所能表示的最大数
; # 查询表在哪个数据库与注释 SELECT TABLE_SCHEMA, TABLE_NAME, TABLE_COMMENT FROM information_schema.TABLES WHERE...1=1 # AND TABLE_SCHEMA = '数据库名' AND TABLE_NAME = '表名' # AND TABLE_COMMENT = '表注释' ; # 查询列在哪个表与注释 SELECT...information_schema.TABLES t ON t.TABLE_NAME = c.TABLE_NAME WHERE 1=1 # AND TABLE_SCHEMA = '数据库名' # AND TABLE_NAME = '表名...COLUMN_COMMENTS FROM information_schema.COLUMNS WHERE 1=1 AND TABLE_SCHEMA = 'test' # AND TABLE_NAME = '表名
-- 新建表时判断表是否存在 CREATE TABLE If Not Exists `表名` ( `id` int(10) NOT NULL AUTO_INCREMENT , `plan_id` ...bet_num` varchar(255) NULL , `vr_win_data` varchar(255) NULL COMMENT , PRIMARY KEY (`id`) ); -- 新建字段时判断字段是否存在...EXISTS (SELECT * FROM information_schema.columns WHERE table_schema = DATABASE() AND table_name = '表名..._888(); drop procedure IF EXISTS sp_update_888; -- 新建索引时判断索引是否存在 CREATE PROCEDURE sp_update_888...EXISTS (SELECT * FROM information_schema.statistics WHERE table_schema=DATABASE() AND table_name = '表名
登录mysql终端 mysql -uroot -p 输入密码: 进入mysql> 1.日志文件路径 mysql> show variables like ‘general_log_file...localhost.log | ±-----------------±-----------------------------------+ 1 row in set (0.00 sec) 2.错误日志文件路径...mysql> show variables like ‘log_error’; ±--------------±-----------------------------------+ | Variable_name...| ±--------------±-----------------------------------+ 1 row in set (0.00 sec) 3.慢查询日志文件路径 mysql> show...±--------------------±----------------------------------------+ | slow_query_log_file | /usr/local/mysql
INSERT INTO `swork_info`.`quality_data_app_base_value` (`gmt_create`, `gmt_modi...
一、Mysql的配置 my.cnf位置 1)、使用命令: ps aux|grep mysql|grep 'my.cnf' 如果没有没有输出内容则是使用默认配置位置 二、默认配置my.cnf位置 使用命令...: mysql --help|grep 'my.cnf' /etc/my.cnf、/etc/mysql/my.cnf、 /usr/local/etc/my.cnf、 ~/.my.cnf 顺序排前的优先
登录mysql终端 日志文件路径 mysql> show variables like ‘general_log_file’; +——————+————————————+ | Variable_name...| Value | +——————+————————————+ | general_log_file | /usr/local/mysql.../data/localhost.log | +——————+————————————+ 1 row in set (0.00 sec) 错误日志文件路径 mysql> show variables...Variable_name | Value | +—————+————————————+ | log_error | /usr/local/mysql.../data/localhost.err | +—————+————————————+ 1 row in set (0.00 sec) 慢查询日志文件路径 mysql> show variables
图 | 榖依米 下午,所有的SQL慢如牛。 平日里2-3秒搞定的SQL,这会非得弄个7-8秒。timeout更是频频爆出。搞得办公室怨叫声此起彼伏,真有点《生命协奏曲》的味道。...幸好只是开发库,只有数量不多的连接,一查就知道,某个SQL发出了SOS的等待,占用大量的CPU,而且还在拼命的发出多线程请求。截获了它的SQL文本,拿出来一看,差点吓尿。 ?...排除那些复杂的 Index Spool,Stream Aggregation,这里面最吸引我的是同一张表,居然要扫描两次,就是那张 XXX_PER表。...所以我不得不重新看下这段SQL的逻辑,简直是鬼才! 这种写法,大约就是“只有我看得懂的SQL,你们离不开我”的想法作祟下,搞出来的鬼。据我经验分析,往往都是刚出道的小聪明。...但凡看到我之前写过的文章 如何写好 5000 行的 SQL 代码,是绝对不可能写出这样的SQL。要么没懂重构的意义,要么就是甩小聪明。 所以,我做了些小调整: ?
1.导出整个数据库 mysqldump -u 用户名 -p 数据库名 > 导出的文件名 mysqldump -u dbuser -p dbname > dbname.sql 2.导出一个表...mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 mysqldump -u dbuser -p dbname users> dbname_users.sql 3.导出一个数据库结构...mysqldump -u dbuser -p -d --add-drop-table dbname >d:/dbname_db.sql -d 没有数据 --add-drop-table 在每个create...语句之前增加一个drop table 4.导入数据库 常用source 命令 进入mysql数据库控制台,如 mysql -u root -p mysql>use 数据库 然后使用source...命令,后面参数为脚本文件(如这里用到的.sql) mysql>source d:/dbname.sql
-u dbuser -p dbname > dbname.sql 2.导出一个表 mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 mysqldump -u dbuser -p...-p mysql>use 数据库 然后使用source命令,后面参数为脚本文件(如这里用到的.sql) mysql>source d:/dbname.sql 1. ...> ligh tinthebox.sql linux下 一、导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径): 1、导出数据和表结构: mysqldump -u用户名 -...p密码 数据库名 > 数据库名.sql #/usr/local/mysql/bin/ mysqldump -uroot -p abc > abc.sql 敲回车后会提示输入密码 2、只导出表结构 mysqldump...>use abc; (2)设置数据库编码 mysql>set names utf8; (3)导入数据(注意sql文件的路径) mysql>source /home/abc/abc.sql; 方法二: mysql
记录一下数据库导入文件方法~ 方案一 登录数据库 mysql -u root -p123 检查已经存在的数据库 show databases; 创建新的数据库 create database test...; # 查看已经存在的是为了避免重复创建 选择你所创建的数据库 use test; 导入sql文件 source db-test.sql; #注意sql文件的路径 查看导入结果 show tables;...退出数据库 exit; 方案二 mysql -u root -p123 test < test.sql # mysql -u 用户名 -p 密码 数据库名 < 数据库名.sql
我想碎片的情况在数据库中是很少有清晰的界定,不过它的的确确会带来副作用,通过修复碎片情况我们可以提高SQL的执行效率,同时能够释放大量的空间。...但是在这里我们总是会感觉有些隔靴搔痒,因为我们通过计算得到了逻辑大小,但是我们还是无从得知物理文件的大小,如果逐个去通过du方式计算,这个成本是很高的,而且如果有很多的表,这种模式的效率和代价是不大合理的...的物理文件大小(即.ibd文件),可以通过INNODB_SYS_TABLESPACES 来查询得到,这是一个缓存中刷新得到的实时的值,远比我们通过du等方式计算要快捷方便许多。...50M左右,而物理文件大小是60M左右,那么碎片率大约是(60-50)/60约等于16.7% 我们做一下数据的truncate操作,发现物理文件的大小很快收缩了。...当然这种计算方式是不够完整的,而且不够清晰,我们可以写一个简单的SQL来做下统计,就是把那些需要修复的表列出来即可。
如题: 需要本地安装mysqlbinlog 命令 mysql-bin.000046 binlog 文件 lzerp 数据库名称 /home/46.sql 导出sql 文件的目录 mysqlbinlog...--base64-output=decode-rows -v mysql-bin.000046 -d lzerp > /home/46.sql
SQl 语句(常见) 新建,删除,修改表结构 新建表: create table [表名] ( [自动编号字段] int IDENTITY (1,1) PRIMARY KEY , [字段1] nVarChar...Drop table [表名] 插入数据: INSERT INTO [表名] (字段1,字段2) VALUES (100,'51WINDOWS.NET') 删除数据: DELETE FROM [表名...: ALTER TABLE [表名] ADD [字段名] NVARCHAR (50) NULL 删除字段: ALTER TABLE [表名] DROP COLUMN [字段名] 修改字段: ALTER...'表名', '新表名', 'OBJECT' 新建约束: ALTER TABLE [表名] ADD CONSTRAINT 约束名 CHECK ([约束字段] <= '2000-1-1') 删除约束:...ALTER TABLE [表名] DROP CONSTRAINT 约束名 新建默认值 ALTER TABLE [表名] ADD CONSTRAINT 默认值名 DEFAULT '51WINDOWS.NET
SQl 语句(常见) 新建,删除,修改表结构 新建表: create table [表名] ( [自动编号字段] int IDENTITY (1,1) PRIMARY KEY , [字段1]...Drop table [表名] 插入数据: INSERT INTO [表名] (字段1,字段2) VALUES (100,'51WINDOWS.NET') 删除数据: DELETE FROM [表名...: ALTER TABLE [表名] ADD [字段名] NVARCHAR (50) NULL 删除字段: ALTER TABLE [表名] DROP COLUMN [字段名] 修改字段: ALTER...'表名', '新表名', 'OBJECT' 新建约束: ALTER TABLE [表名] ADD CONSTRAINT 约束名 CHECK ([约束字段] <= '2000-1-1') 删除约束:...ALTER TABLE [表名] DROP CONSTRAINT 约束名 新建默认值 ALTER TABLE [表名] ADD CONSTRAINT 默认值名 DEFAULT '51WINDOWS.NET
领取专属 10元无门槛券
手把手带您无忧上云