mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-21 08:47:42 +03:00 
			
		
		
		
	The problem was that when converting a string to an exact number, rounding didn't work, because conversion didn't understand approximate numbers notation. Fix: a new function for string-to-number conversion was implemented, which is aware of approxinate number notation (with decimal point and exponent, e.g. -19.55e-1) include/m_ctype.h: Adding new function into MY_CHARSET_HANDLER Adding prototypes for 8bit and ucs2 functions. mysql-test/r/loaddata.result: Fixing results mysql-test/r/ps_2myisam.result: Fixing results mysql-test/r/ps_3innodb.result: Fixing results mysql-test/r/ps_4heap.result: Fixing results mysql-test/r/ps_5merge.result: Fixing results mysql-test/r/ps_6bdb.result: Fixing results mysql-test/r/rpl_rewrite_db.result: Fixing results mysql-test/r/select.result: Fixing results mysql-test/r/sp-vars.result: Fixing results mysql-test/r/strict.result: Fixing results mysql-test/r/view.result: Fixing results mysql-test/r/warnings.result: Fixing results mysql-test/t/strict.test: Fixing results sql/field.cc: Using new function strings/ctype-big5.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-bin.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-cp932.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-euc_kr.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-eucjpms.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-gb2312.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-gbk.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-latin1.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-simple.c: Implementing my_strntoull10_8bit Adding new function into MY_CHARSET_HANDLER strings/ctype-sjis.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-tis620.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-ucs2.c: Implementing UCS2 wrapper for 8bit version Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-ujis.c: Adding new function into the MY_CHARSET_HANDLER structure strings/ctype-utf8.c: Adding new function into the MY_CHARSET_HANDLER structure mysql-test/r/round.result: New BitKeeper file ``mysql-test/r/round.result'' mysql-test/t/round.test: New BitKeeper file ``mysql-test/t/round.test''
		
			
				
	
	
		
			146 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| --disable_warnings
 | |
| DROP TABLE IF EXISTS t1;
 | |
| --enable_warnings
 | |
| 
 | |
| CREATE TABLE t1 (sint8 tinyint not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('127.4');
 | |
| INSERT INTO t1 VALUES ('127.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('-127.4');
 | |
| INSERT INTO t1 VALUES ('-127.5');
 | |
| INSERT INTO t1 VALUES ('-128.4');
 | |
| INSERT INTO t1 VALUES ('-128.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (uint8 tinyint unsigned not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('127.4');
 | |
| INSERT INTO t1 VALUES ('127.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('255.4');
 | |
| INSERT INTO t1 VALUES ('255.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| 
 | |
| CREATE TABLE t1 (sint16 smallint not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('32767.4');
 | |
| INSERT INTO t1 VALUES ('32767.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('-32767.4');
 | |
| INSERT INTO t1 VALUES ('-32767.5');
 | |
| INSERT INTO t1 VALUES ('-32768.4');
 | |
| INSERT INTO t1 VALUES ('-32768.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| 
 | |
| CREATE TABLE t1 (uint16 smallint unsigned not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('32767.4');
 | |
| INSERT INTO t1 VALUES ('32767.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('65535.4');
 | |
| INSERT INTO t1 VALUES ('65535.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (sint24 mediumint not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('8388607.4');
 | |
| INSERT INTO t1 VALUES ('8388607.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('-8388607.4');
 | |
| INSERT INTO t1 VALUES ('-8388607.5');
 | |
| INSERT INTO t1 VALUES ('-8388608.4');
 | |
| INSERT INTO t1 VALUES ('-8388608.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (uint24 mediumint unsigned not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('8388607.4');
 | |
| INSERT INTO t1 VALUES ('8388607.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('16777215.4');
 | |
| INSERT INTO t1 VALUES ('16777215.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (sint64 bigint not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('9223372036854775807.4');
 | |
| INSERT INTO t1 VALUES ('9223372036854775807.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('-9223372036854775807.4');
 | |
| INSERT INTO t1 VALUES ('-9223372036854775807.5');
 | |
| INSERT INTO t1 VALUES ('-9223372036854775808.4');
 | |
| INSERT INTO t1 VALUES ('-9223372036854775808.5');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (uint64 bigint unsigned not null);
 | |
| INSERT INTO t1 VALUES ('0.1');
 | |
| INSERT INTO t1 VALUES ('0.5');
 | |
| INSERT INTO t1 VALUES ('9223372036854775807.4');
 | |
| INSERT INTO t1 VALUES ('9223372036854775807.5');
 | |
| INSERT INTO t1 VALUES ('-0.1');
 | |
| INSERT INTO t1 VALUES ('-0.5');
 | |
| INSERT INTO t1 VALUES ('18446744073709551615.4');
 | |
| INSERT INTO t1 VALUES ('18446744073709551615.5');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.0');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.2');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.3');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.4');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.5');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.0e1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.1e1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.2e1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.3e1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.4e1');
 | |
| INSERT INTO t1 VALUES ('1844674407370955161.5e1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551610e-1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551611e-1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551612e-1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551613e-1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551614e-1');
 | |
| INSERT INTO t1 VALUES ('18446744073709551615e-1');
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| CREATE TABLE t1 (str varchar(128), sint64 bigint not null default 0);
 | |
| INSERT INTO t1 (str) VALUES ('1.5');
 | |
| INSERT INTO t1 (str) VALUES ('1.00005e4');
 | |
| INSERT INTO t1 (str) VALUES ('1.0005e3');
 | |
| INSERT INTO t1 (str) VALUES ('1.005e2');
 | |
| INSERT INTO t1 (str) VALUES ('1.05e1');
 | |
| INSERT INTO t1 (str) VALUES ('1.5e0');
 | |
| INSERT INTO t1 (str) VALUES ('100005e-1');
 | |
| INSERT INTO t1 (str) VALUES ('100050e-2');
 | |
| INSERT INTO t1 (str) VALUES ('100500e-3');
 | |
| INSERT INTO t1 (str) VALUES ('105000e-4');
 | |
| INSERT INTO t1 (str) VALUES ('150000e-5');
 | |
| UPDATE t1 SET sint64=str;
 | |
| SELECT * FROM t1;
 | |
| DROP TABLE t1;
 | |
| 
 | |
| 
 |