我曾try 在脚本中使用此代码,但它只是创建了反引号内的内容.在本例中,在数据库中创建了"echo"table-db"".它没有在查询中创建带有连字符的文件夹名称

hyph=`ls -l $DBDIR | egrep '^d' | grep '.-.' | awk '{print $9}'`

dbhype=($hyph)


for dbtry in ${!dbhype[*]}
   do            
        mysql -u$dbUser -p$dbPass -e 'CREATE DATABASE IF NOT EXISTS `echo "table-db"` CHARACTER SET utf8 COLLATE utf8_general_ci';

        echo "Database ${dbhype[$dbtry]} created."

done

推荐答案

在MySQL查询中,表名由may contain个字母数字字符、下划线和美元符号组成.为了能够使用其他ANSI字符,您必须将名称放在单反引号中.

`table-db`

但在bash中,它们有不同的含义,用于command substitution.bash中还有几种类型的字符串——双引号和单引号.它们之间的区别在于,在双引号中执行变量扩展和命令替换,而在单引号中则不执行.因此,可以在单引号中使用带mysql语义的反引号

mysql -e 'CREATE DATABASE `table-db`;'

但是在双引号内使用时必须对它们进行转义,这样bash就不会将它们解释为命令表示.

mysql -e "CREATE DATABASE \`table-db\`;"

由于您希望从变量中获取数据库名称,因此需要将其放在单引号字符串之外,如下所示:

mysql -e "CREATE DATABASE \`$dbname\`;"

或者像这样:

mysql -e 'CREATE DATABASE `'$dbname'`;'

Database相关问答推荐

使用Postgres获取带有表架构的外键

如何以编程方式将产品添加到 Opencart 数据库

什么是范围锁( range-locks)?

如何在我的 Rails 应用程序中避免竞争条件?

数据库设计:多表与单表

递归关系的数据库设计

如何在 Oracle 中找到指向一条记录的外键依赖项?

如何在 VS 2012 的 SQL Server 数据库项目中存储静态数据

为什么 MySQL 连接被许多连接错误阻止?

ORA-00060: deadlock detected while waiting for resource

日期范围重叠判断约束

JPA:处理 OptimisticLockException 的模式

判断Android中的应用程序数据库中是否存在列

如何在实体-属性-值设计中处理不同的数据类型(例如,具有多列的单个表或每种数据类型的多个表)?

数以百万计的条目排名

ORM 还是Vietnam of Computer Science吗?

MySQL中的eq_ref和ref类型是什么意思解释

Django + PostgreSQL:如何重置主键?

最佳用户角色权限数据库设计实践?

如何在 SQLServer 数据库的两个实例之间复制数据记录