PHPize Online / SQLize Online  /  SQLtest Online

A A A
Share      Blog   Popular
Copy Format Clear
DROP TABLE IF EXISTS users; DROP TABLE IF EXISTS products; DROP TABLE IF EXISTS user_carts; CREATE TABLE users ( id INT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL UNIQUE, password VARCHAR(255) NOT NULL ); CREATE TABLE products ( id INT PRIMARY KEY AUTO_INCREMENT, product_name VARCHAR(255) NOT NULL, price DECIMAL(10, 2) NOT NULL ); CREATE TABLE user_carts ( cart_id INT PRIMARY KEY AUTO_INCREMENT, user_id INT NOT NULL, product_id INT NOT NULL, quantity INT NOT NULL, FOREIGN KEY (user_id) REFERENCES users(id), FOREIGN KEY (product_id) REFERENCES products(id) ); -- Индексы записал здесь, пишу на основании запросов, но в жизни скорее всего нужны будут индексы по таблице пользователей: по email и password -- Вспоминая пояснение что можно по составному индексу использовать только первое значение, то для этой задачи достаточно одного индекса CREATE INDEX user_product ON user_carts(user_id, product_id); INSERT INTO users (username,email,password) VALUES ('user1','email1','passw1'),('user2','email2','passw2'),('user2','email3','passw3'); INSERT INTO products (product_name,price) VALUES ('name1',111),('name2',222),('name3',333),('name4',444),('name5',555); INSERT INTO user_carts (user_id, product_id, quantity) VALUES (1,1,2),(1,2,3),(3,5,3),(3,2,3); -- Запрос, который вернёт список товаров пользователя SELECT -- перечилить все поля какие нужны или поставить * * FROM user_carts JOIN products ON user_carts.product_id = products.id WHERE user_carts.user_id = 3; -- Запрос, который покажет, есть ли у конкретного пользователя конкретный товар SELECT COUNT(*) AS count FROM user_carts WHERE user_id = 3 AND product_id = 5; -- Запрос, который получает список всех пользователей, у которых корзина пуста, т.е. нет записей в таблице user_carts -- вариант 1 SELECT users.id FROM users WHERE id NOT IN (SELECT user_id FROM user_carts); -- вариант 2, здесь я вспомнил разговор про Null и Left Join SELECT users.id FROM users LEFT JOIN user_carts ON users.id = user_carts.user_id WHERE user_carts.user_id IS NULL; -- Сложно сказать какой запрос быстрее, второй возможно будет быстрее, но результаты на холодной базе показывают примерно одинаковое время -- Проверял 5млн корзин, 100к товаров и 100к пользоватей, размер БД был близким к 500мб
Copy Clear
Copy Format Clear
<?php class Complex implements JsonSerializable { private readonly float $a; private readonly float $b; public function __construct(float $a, float $b) { $this->a = $a; $this->b = $b; } public function __toString(): string { $sign = ($this->b >= 0) ? '+' : '-'; return $this->a.$sign.abs($this->b).'i'; } final public function getA(): float { return $this->a; } final public function getB(): float { return $this->b; } public function jsonSerialize(): string { return json_encode(['real' => $this->a, 'imaginary' => $this->b]); } public function plus(Complex $complex2): Complex { $a = $this->a + $complex2->a; $b = $this->b + $complex2->b; return new Complex($a, $b); } public function minus(Complex $complex2): Complex { $a = $this->a - $complex2->a; $b = $this->b - $complex2->b; return new Complex($a, $b); } public function multiply(Complex $complex2): Complex { $c=$complex2->a; $d=$complex2->b; $a = $this->a*$c - $this->b*$d; $b = $this->b*$c + $this->a*$d; return new Complex($a, $b); } public function divide(Complex $complex2): Complex { $c=$complex2->a; $d=$complex2->b; $delim = pow($c,2) + pow($d,2); $a = ($this->a*$c + $this->b*$d)/$delim; $b = ($this->b*$c - $this->a*$d)/$delim; return new Complex($a, $b); } } $complex1 = new Complex(1, 2); $complex2 = new Complex(3, 4); $result = $complex1->divide($complex2); echo $result . PHP_EOL; var_dump(json_encode($result));
Show:  
Copy Clear