You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-10-22 22:32:34 +03:00
156 lines
7.2 KiB
Bash
Executable File
156 lines
7.2 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# $Id$
|
|
#
|
|
|
|
prefix=/usr/local
|
|
installdir=$prefix/mariadb/columnstore
|
|
rpmmode=install
|
|
pwprompt=" "
|
|
|
|
for arg in "$@"; do
|
|
if [ `expr -- "$arg" : '--prefix='` -eq 9 ]; then
|
|
prefix="`echo $arg | awk -F= '{print $2}'`"
|
|
installdir=$prefix/mariadb/columnstore
|
|
elif [ `expr -- "$arg" : '--rpmmode='` -eq 10 ]; then
|
|
rpmmode="`echo $arg | awk -F= '{print $2}'`"
|
|
elif [ `expr -- "$arg" : '--installdir='` -eq 13 ]; then
|
|
installdir="`echo $arg | awk -F= '{print $2}'`"
|
|
prefix=`dirname $installdir`
|
|
elif [ `expr -- "$arg" : '--tmpdir='` -eq 9 ]; then
|
|
tmpdir="`echo $arg | awk -F= '{print $2}'`"
|
|
else
|
|
echo "ignoring unknown argument: $arg" 1>&2
|
|
fi
|
|
done
|
|
|
|
df=$installdir/mysql/my.cnf
|
|
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --force --user=root mysql 2> ${tmpdir}/mysql_install.log <<EOD
|
|
INSTALL PLUGIN columnstore SONAME 'libcalmysql.so';
|
|
INSTALL PLUGIN columnstore_tables SONAME 'is_columnstore_tables.so';
|
|
INSTALL PLUGIN columnstore_columns SONAME 'is_columnstore_columns.so';
|
|
INSTALL PLUGIN columnstore_extents SONAME 'is_columnstore_extents.so';
|
|
INSTALL PLUGIN columnstore_files SONAME 'is_columnstore_files.so';
|
|
-- these are deprecated names
|
|
DELETE FROM mysql.func WHERE name='caldisablepartition';
|
|
DELETE FROM mysql.func WHERE name='caldroppartition';
|
|
DELETE FROM mysql.func WHERE name='calenablepartition';
|
|
DELETE FROM mysql.func WHERE name='caldisablepartitions';
|
|
DELETE FROM mysql.func WHERE name='calenablepartitions';
|
|
DELETE FROM mysql.func WHERE name='caldroppartitions';
|
|
DELETE FROM mysql.func WHERE name='calshowpartitions';
|
|
DELETE FROM mysql.func WHERE name='caldroppartitionsbyvalue';
|
|
DELETE FROM mysql.func WHERE name='caldisablepartitionsbyvalue';
|
|
DELETE FROM mysql.func WHERE name='calenablepartitionsbyvalue';
|
|
DELETE FROM mysql.func WHERE name='calshowpartitionsbyvalue';
|
|
-- these functions moved libs
|
|
DROP FUNCTION caldisablepartitions;
|
|
DROP FUNCTION calenablepartitions;
|
|
DROP FUNCTION caldroppartitions;
|
|
DROP FUNCTION calshowpartitions;
|
|
DROP FUNCTION caldroppartitionsbyvalue;
|
|
DROP FUNCTION caldisablepartitionsbyvalue;
|
|
DROP FUNCTION calenablepartitionsbyvalue;
|
|
DROP FUNCTION calshowpartitionsbyvalue;
|
|
CREATE FUNCTION calgetstats RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calsettrace RETURNS INTEGER SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calsetparms RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calflushcache RETURNS INTEGER SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calgettrace RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calgetversion RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calonlinealter RETURNS INTEGER SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calviewtablelock RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calcleartablelock RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION caldisablepartitions RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calenablepartitions RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION caldroppartitions RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calshowpartitions RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION callastinsertid RETURNS INTEGER SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION caldroppartitionsbyvalue RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION caldisablepartitionsbyvalue RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calenablepartitionsbyvalue RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calshowpartitionsbyvalue RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION calgetsqlcount RETURNS STRING SONAME 'libcalmysql.so';
|
|
CREATE FUNCTION idbpm RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbdbroot RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbsegment RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbsegmentdir RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbextentrelativerid RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbblockid RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbextentid RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbextentmin RETURNS STRING soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbextentmax RETURNS STRING soname 'libcalmysql.so';
|
|
CREATE FUNCTION idbpartition RETURNS STRING soname 'libcalmysql.so';
|
|
CREATE FUNCTION idblocalpm RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION mcssystemready RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION mcssystemreadonly RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE FUNCTION mcssystemprimary RETURNS INTEGER soname 'libcalmysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_avgx RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_avgy RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_count RETURNS INTEGER soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_slope RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_intercept RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_r2 RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION corr RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_sxx RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_syy RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION regr_sxy RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION covar_pop RETURNS REAL soname 'libregr_mysql.so';
|
|
CREATE AGGREGATE FUNCTION covar_samp RETURNS REAL soname 'libregr_mysql.so';
|
|
|
|
CREATE AGGREGATE FUNCTION distinct_count RETURNS INTEGER soname 'libudf_mysql.so';
|
|
|
|
CREATE DATABASE IF NOT EXISTS infinidb_vtable;
|
|
CREATE DATABASE IF NOT EXISTS infinidb_querystats;
|
|
CREATE TABLE IF NOT EXISTS infinidb_querystats.querystats
|
|
(
|
|
queryID bigint NOT NULL AUTO_INCREMENT,
|
|
sessionID bigint DEFAULT NULL,
|
|
host varchar(50),
|
|
user varchar(50),
|
|
priority char(20),
|
|
queryType char(25),
|
|
query varchar(8000),
|
|
startTime timestamp NOT NULL,
|
|
endTime timestamp NOT NULL,
|
|
\`rows\` bigint,
|
|
errno int,
|
|
phyIO bigint,
|
|
cacheIO bigint,
|
|
blocksTouched bigint,
|
|
CPBlocksSkipped bigint,
|
|
msgInUM bigint,
|
|
msgOutUm bigint,
|
|
maxMemPct int,
|
|
blocksChanged bigint,
|
|
numTempFiles bigint,
|
|
tempFileSpace bigint,
|
|
PRIMARY KEY (queryID)
|
|
);
|
|
|
|
CREATE TABLE IF NOT EXISTS infinidb_querystats.user_priority
|
|
(
|
|
host varchar(50),
|
|
user varchar(50),
|
|
priority char(20)
|
|
) DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
|
|
|
CREATE TABLE IF NOT EXISTS infinidb_querystats.priority
|
|
(
|
|
priority char(20) primary key,
|
|
priority_level int
|
|
) DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
|
|
|
|
insert ignore into infinidb_querystats.priority values ('High', 100),('Medium', 66), ('Low', 33);
|
|
EOD
|
|
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --user=root mysql 2>/dev/null <$installdir/mysql/syscatalog_mysql.sql
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --user=root mysql 2>/dev/null <$installdir/mysql/calsetuserpriority.sql
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --user=root mysql 2>/dev/null <$installdir/mysql/calremoveuserpriority.sql
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --user=root mysql 2>/dev/null <$installdir/mysql/calshowprocesslist.sql
|
|
$installdir/mysql/bin/mysql --defaults-extra-file=$df --user=root mysql 2>/dev/null <$installdir/mysql/columnstore_info.sql
|
|
|
|
sed -i 's/infinidb_compression_type=1/infinidb_compression_type=2/' $installdir/mysql/my.cnf >/dev/null 2>&1
|
|
|